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una 

scheda video 

per il vostro 

microprocessore 

YU3UMV, ìng. Matjaz Vidmar 


Introduzione 

Su varie riviste di elettronica sono stati già pubblicati diversi 
schemi di terminali video e schede d’interfaccia video per 
microcomputer. 

Anche sul mercato sono disponibili diverse soluzioni: apparec¬ 
chi completi, montati e inscatolati, schede premontate e appa¬ 
recchi in forma di kit. 

Analizzando però le varie soluzioni circuitali adottate si scopro¬ 
no parecchi difetti: 

- La flessibilità d’impiego: le funzioni dell’interfaccia video so¬ 
no generalmente realizzate o con un integrato LSI dedicato, un 
“CRT controller", oppure con alcune dozzine d’integrati TTL; in 
ogni caso le funzioni sono realizzate via hardware, perciò è 
molto difficile fare deile modifiche e/o aggiungere funzioni 
nuove. 

- La reperibilità dei componenti: / generatori di caratteri (me¬ 
morie ROM) e i CRT controllers non rappresentano nulla di nuo¬ 
vo per quanto riguarda la tecnologia di costruzione se confron¬ 
tati con i vari microprocessori, RAM e EPROM reperibili in com¬ 
mercio; mentre per le RAM e le EPROM i tipi sono standardizza¬ 
ti e tutti i produttori di circuiti integrati producono gli stessi tipi di 
memorie, i generatori di caratteri e ancora più i CRT controllers 
non sono standardizzati e ogni fabbrica produce i suoi integrati 
che, anche se simili agli integrati della concorrenza, non sono 
quasi mai equivalenti. 

- Il costo dell’apparecchio: sembra che i progettisti di questi 
apparecchi non si preoccupino del costo della realizzazione: 
generatori di caratteri, CRT controllers costosissimi e costose 
PROM difficili da reperire prima e da programmare poi. 
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Progettando la scheda video che presento in questo articolo ho cercato di 
ovviare a questi inconvenienti: naturalmente era necessario un compro¬ 
messo tra le varie richieste. 

Innanzitutto ho deciso di collegare la scheda video direttamente al bus del 
microprocessore. La scrittura nella memoria RAM della scheda video viene 
eseguita dal microprocessore. In questo modo tutte le funzioni di scrittura 
vengono eseguite dal software: scrittura carattere, nuova linea, ritorno 
all'inizio della linea, cancellazione riga e pagina, scroll e cursore. Per modi¬ 
ficare le funzioni o aggiungerne delle nuove basta modificare il programma. 
L’organizzazione della RAM della scheda video é di 4k x 8 bit (vedi figura 1). 



Al mceomocfiScwL 


figura 1 

Schema a blocchi della scheda video. 


Metà della RAM è dedicata alla rappresentazione di 32 righe di 64 caratteri 
ciascuna mentre l'altra metà può essere liberamente impiegata dal micro- 
processore per non rallentare troppo il funzionamento di quest’ultimo. 

In commercio sono reperibili vari tipi di generatori di caratteri, personal¬ 
mente ho però preferito programmare una EPROM con i seguenti vantaggi: 
- i generatori di caratteri commerciali hanno generalmente 64 caratteri 
ASCII (lettere maiuscole e cifre), programmando una EPROM 2708 si pos¬ 
sono invece ottenere 128 caratteri: tutti i 96 caratteri ASCII (lettere maiu¬ 
scole, minuscole e cifre) e in più 32 caratteri grafici: 
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- la EPROM 2708 è un NMOS e ha un tempo d'accesso circa due volte infe¬ 
riore dei generatori di caratteri commerciali, che sono dei PMOS; questo 
fatto semplifica notevolmente il progetto della scheda video (non sono ne¬ 
cessari dei latch TTL); 

- la 2708 é facilmente reperibile e costa meno dei generatori di caratteri 
commerciali. 

La logica attorno alle memorie deve essere assai veloce, la frequenza di 
clock è di 12 MHz. Per non avere problemi di temporizzazione ho impiegato 
i comuni TTL, comunque nulla vieta di sostituirli con la serie LS a consumo ri¬ 
dotto. 

Descrizione del circuito 

Tutte le frequenze necessarie al funzionamento della scheda vengono ot¬ 
tenute tramite la divisione del clock a 12 MHz (vedi figura 2). 

I due 74161 e il 74112 dividono i 12 MHz per 768 (16x16x3); alle uscite del 
74112 troviamo la frequenza di lìnea TV di 15.625 Hz, Metà del 74109, il 
74193 e il 7490 dividono questa frequenza per 320 (2x16x10) per ottenere 
la frequenza di quadro. Il quadro ha perciò 320 linee al posto delle 312,5 li¬ 
nee dello standard CCIR, i TV-monitor non sono molto sensibili alle piccole 
variazioni della frequenza di quadro. Tramite opp ortuni c ircuiti decodifica 
si astraggono i segnali di sincronismo HSYNC e VSYNCT Ho preferito ese¬ 
guire le uscite dei segnali di sincronismo e l'uscita del segnale video sepa¬ 
rate, in questo modo si possono pilotare anche direttamente i circuiti di 
deflessione del CRT e lo stadio finale video. Per pilotare un TV monitor si 
può aggiungere un mixer (vedi più avanti alla figura 8). 

Una linea TV dura 64 ps, considerando il tempo di ritraccia e un certo mar¬ 
gine ai bordi dell’immagine rimangono 40 -=-45 ps utili. Con il circuito pre¬ 
sentato un carattere dura 666 ns (frequenza di ripetizione 1,5 MHz) e una 
riga di 64 caratteri occupa 42,6 ps (% dell’intera riga TV). Il primo 74161 con 
le relative porte di decodifica ha il compito d i ge nerare gli impulsi a 
1,5 MHz per pilotare la lettura dalle RAM: impulsi RAS, GAS e trasferimen¬ 
to nello shift register PET 

I caratteri sono formati da un mosaico di 8 punti x 8 linee; i caratteri alfanu¬ 
merici sono formati da 7 punti x 7 linee utili, una linea e una colonna vengo¬ 
no utilizzate per la separazione tra i caratteri. I dati di una linea di un carat¬ 
tere (8 bit) vengono letti in parallelo dal generatore di caratteri e caricati in 
un veloce shift register TTL, all’uscita serie dello shift register si ottiene il 
segnale video. La frequenza di clock dello shift register è 12 MHz, cioè otto 
volte la frequenza di ripetizione dei caratteri. La larghezza di banda del se¬ 
gnale video ottenuto è perciò 6 MHz minimi. 

Una riga ha 64 caratteri, per indirizzarli è necessario fornire 6 bit di address 
(2 6 = 64) alla memoria RAM (HAO -5- HA5 su figura 2). 

I caratteri sono alti 8 linee, 32 righe di caratteri occupano perciò 256 linee 
TV. Dalle 320 linee del quadro rimangono 64 linee per la ritraccia verticale 
e un certo margine in cima e in fondo dell’immagine. Per scansionare le 32 
righe del testo sono necessari 5 address verticali VA0 -e VA4. Durante la 
scansione di una riga del testo (8 linee TV) gli address verticali della RAM 
(VA0 + VA4) rimangono fissi, viene invece scansionato il generatore di ca¬ 
ratteri tramite RS0, RS1 e RS2. 

Le otto RAM impiegate sono da4kx 1 bit dinamiche con gli address multi- 
plexati (vedi figura 4). 
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Il multiplexer costituito dai tre 74153 (vedi figura 3) ha due scopi: 

- di multiplexare i 12 bit necessari per indirizzare 4k di memoria sulle 6 li¬ 
nee di address delle memorie MAO -r- MA5; 

- di commutare gli address della memoria tra il microprocessore e la logica 
di scansione della scheda video. 


La scheda video collegata a un microcomputer. 
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una scheda video per il vostro microprocessore 

Il microprocessore chiede di comunicare con la memoria RAM (leggere o 
scrivere) inviando un livello logico basso all'entrata C5della scheda video. 
Poiché i circuiti della scheda video generalmente non sono sincronizzati 
con il microprocessore, per primo devono completare il presente ciclo di 
lettura. La sincronizzazione vien e eff ettuata dal latch 74298. Le memorie 
ricevono sempre gli stessi clock RAS e GAS, però tramite il multiplexer ri¬ 
cevono gli address dal microprocessore. Nel caso di una lettura della RAM 
vengono anche abilitati i tri-state buffer che connettono le uscite delle 
memorie al data bus del pp. 

Quando le memorie RAM comunicano col pp non possono allo stesso tem¬ 
po inviare i dati giusti al generatore di caratteri. Il disturbo si presenta co¬ 
me uno sfarfallio sullo schermoTV. Per minimizzare l’effetto del disturbo la 
logica blocca nel momento opportuno il trasferimento dei dati dal genera¬ 
tore di caratteri nello shift register. In questo modo la parte mancante del 
carattere viene sostituita da un trattino scuro. 

Per la sincronizzazione della richiesta del microprocessore è richiesto un 
certo tempo, perciò il tempo complessivo d’accesso alla memoria può arri¬ 
vare anche a 1,3 ps. La soluzione più semplice è di ridurre la frequenza del 
clock del pp per adattarlo alla memoria della scheda video. 

Le memorie RAM dinamiche richiedono per il mantenimento dei dati dei 
cicli di refresh, generalmente ogni 2 ms. Le RAM dinamiche impiegate ri¬ 
chiedono 64 cicli di lettura o scrittura sui 64 possibili row address ogni 2 
ms per il refresh. La memoria RAM è collegata al generatore di scansione 
in modo che durante una linea TV vengono richiamati tutti i 64 row ad¬ 
dress. Il problema del refresh si presenta perciò soltanto quando il micro- 
processore chiede di comunicare con la memoria RAM. Per garantire il re¬ 
fresh su tutti i 64 row address anche nel caso peggiore, ogni 32 linee TV 
(32 x 64 ps = 2.048 ms) la logica viene forzata nella scansione normale (li¬ 
nea REFRESH).Il microprocessore viene preavvisato tramite la linea REA¬ 
DY che la memoria RAM non è disponibile. 

Costruzione 

I componenti della scheda video sono montati su un circuito stampato a 
doppio rame (vedi figure 5, 6 e 7). 

Purtroppo sugli schemi delle figure 2, 3 e 4 non era possibile disegnare i 
condensatori di disaccoppiamento delle linee di alimentazione nelle loro 
esatte posizioni sul circuito stampato. Buona parte delle transizioni dal la¬ 
to componenti al lato rame è realizzata dai piedini dei circuiti integrati, sal¬ 
dati da entrambi i lati, poiché non avevo la possibilità di metallizzare i fori 
della piastrina. Le rimanenti transizioni devono invece essere realizzate da 
spezzoni di filo saldati da entrambi i lati. Tutti gli integrati MOS impiegati 
hanno gli ingressi protetti da almeno un diodo tra l’ingresso e il substrato 
Vbb. Si può facilmente controllare la presenza di questo diodo con un oh- 
metro, portata Q x 100 o Q x 1.000, senza danneggiare l’integrato. Gli inte¬ 
grati MOS impiegati possono perciò essere saldati come i comuni TTL. 
Consiglio di montare su zoccolo soltanto la EPROM 2708 in modo da poter 
facilmente cambiare il character font. Gli integrati NMOS impiegati richie¬ 
dono tre tensioni d’alimentazione: —5 V, +5 V e +12 V. I +5 V servono sol¬ 
tanto per interfacciare i TTL, gran parte del circuito interno dei NMOS vie¬ 
ne alimentata dai +12 V. I —5 V connessi al substrato Vbb hanno circa la 
stessa funzione che aveva la tensione negativa sulla griglia controllo delle 
valvole. Se per un guasto all’alimentatore oppure per una interruzione del¬ 
la pista dei -5 V o un corto viene a mancare la tensione negativa sul piedi¬ 
no Vbb, gli integrati NMOS possono essere distrutti a causa della 
sovradissipazione. 
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figura 7 

Circuito stampato, doppio rame - iato rame. 
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una scheda video per il vostro microprocessore 

In commercio sono reperibili vari tipi di memorie RAM dinamiche da 4k bit. 
Sullo schema sono disegnate le 40965 della Fairchild, gli equivalenti diretti 
sono la MK4096 della Mostek, la 2104 della Intel, la 2660 della Signetics e 
la 6604 della Motorola. Possono però essere impiegati anche altri tipi di 
memorie dinamiche da 4k bit con gli address multiplexati in custodia a 16 
pin, a patto che abbiano il latch all’uscita Dout. Le memorie vengono sele¬ 
zionate per ii tempo d’accesso dalla Casa produttrice. In questo circuito il 
timing non è critico e possono essere impiegate anche le memorie più len¬ 
te (350 ns RAS access time) e quindi più economiche. Anche per la 
EPROM generatore di caratteri va bene il tipo standard con 450 ns di tem¬ 
po d’accesso. 

Nella realizzazione ho impiegato gran parte integrati di recupero dalle 
schede surplus. Anche impiegando integrati nuovi sconsiglio però la co¬ 
struzione "alla cieca". Molte volte succede che anche gli integrati nuovi 
presentano dei difetti. Le Case costruttrici garantiscono generalmente 
l’1°/o o meno esemplari difettosi per la merce di prima scelta, l’esperienza 
però insegna che non è detto che gli integrati pagati cari siano in realtà di 
prima scelta. Per poter portare a termine la realizzazione è essenziale co¬ 
noscere il principio di funzionamento del circuito e disporre di un minimo 
di strumentazione (oscilloscopio). 

Collegamento della scheda video 

La scheda video richiede per il funzionamento un clock esterno a livello 
TTL a 12MHz. Una soluzione economica è rappresentata in figura 8. 



Alimentatone 


HSYNC 


VIDEO 



figura 8 

Circuiti suggeriti per completare la scheda video. 
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Per pilotare un TV monitor è necessario combinare i segnali di sincroni¬ 
smo con il segnale video utile. Con il circuito in figura 8 i caratteri appaiono 
bianchi su fondo scuro. 

Il data bus della scheda video può essere connesso direttamente al data 
bus del microprocessore. Grazie ai buffer "tri-state", il data bus della sche¬ 
da video rappresenta soltanto un carico capacitivo (tranne che in fase di 
lettura), perciò non carica il data bus del gip e non provoca problemi di pilo¬ 
taggio da parte del microprocessore. Gli ingressi del multiplexer della 
scheda video sono degli ingressi TTL e caricano l’address bus del gip. L’in¬ 
gresso CS della scheda video va collegato al decoder degli address più 
significativi. 

Personalmente ho impiegato la scheda video assieme al microprocessore 
8080A. Per interfacciare senza problemi la scheda video ho ridotto la fre¬ 
quenza del clock dello 8080A a 750 kHz (la frequenza massima per lo 
8080A è di 2 MHz). Lo 8080A viene generalmente impiegato assieme al 
8224 generatore di clock e al 8228 data bus buffer e interrupt. L’unico di¬ 
fetto di questi due ultimi integrati è di costare assieme quasi il doppio dello 
8080A. Le loro funzioni possono però essere svolte da pochi TTL di recu¬ 
pero delle schede (vedi figura 9). 

Un 74112 divide per 4 la frequenza di 3 MHz e assieme al 7403 genera i due 
clock 0, e 0 2 per il microprocessore. Il 74298 sincronizza i segnali di reset 
e di ready e memorizza il bit DO dello stato dello 8080A (segnale INTA). La 
logica con il 7400 pilota le memorie (segnale ENABLE) e il circuito per la 
generazione dell'Istruzione RST 7 nel caso di INTA, che in esadecimale 
corrisponde a FF. 

Le subroutines di gestione della scheda video come terminale ASCII occu¬ 
pavano circa 300 bytes di memoria. 



Rappresentazione su monitor TV da 6". Consiglio però t'impiego di un monitor da almeno 9”. 
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Un’altra scheda video collegata a un altro microcomputer. 
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Listing di 128 bytes di programma. 


Conclusioni 

La scheda video che ho presentato in questo articolo non rappresenta l’ul¬ 
timo grido della tecnologia e le soluzioni circuitali adottate sulla scheda 
non permettono al microprocessore di lavorare alla sua massima velocità. 
Come spiegato neH’introduzione, ho cercato di ottenere un compromesso 
tra le varie richieste. 

Riprogettando la scheda si potrebbero adottare varie modifiche: impiega¬ 
re unaEPROM 2716 per avere un characterfont di 256 caratteri, sostituire 
le obsolete RAM dinamiche da 4k bit con RAM dinamiche da 16k bit oppu¬ 
re RAM statiche da 4k bit. 

Forse il difetto maggiore della scheda video è di non essere un apparec¬ 
chio completo e indipendente, visto che è predisposta per essere collega¬ 
ta direttamente al bus di un microprocessore. Naturalmente è possibile 
realizzare su di una scheda separata la logica di scrittura, con integrati TTL 
o CMOS, però oggigiorno la soluzione a microprocessore è decisamente 
più economica. 

Rimango a disposizione per eventuali chiarimenti e/o duplicazione 
EPRO M. © s * ss ss ss ss a # * ss ® ss ss ss & * * ss « # ss ss * ss ss $ * ss * ss © © © © © ss ss 
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... e se gli altri copiano, pazienza! 
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Interfacciamo 
la TI-57 


I4IBR, Marco Ibridi 


“Interfacciare” è certamente uno dei verbi più in voga in questo 
periodo in cui l’informatica galoppa verso mete pressoché 
inimmaginabili, vuoi a cavallo di magnifici puledri IBM o altri, 
vuoi in sella a splendidi Apple, Pet o Trs-80 ma anche sulle ta¬ 
stiere di straordinarie programmabili dalle possibilità fanta¬ 
scientifiche solo fino a qualche anno fa. 

Ciò che io voglio ora proporre è la possibilità di dare, per l’ap¬ 
punto, una voce nuova a una magnifica programmabile quale è 
la TI57 della Texas Instruments. 

Detta programmabile è infatti il cavallo di battaglia di parecchie persone 
che, piu o meno appassionate di elettronica “vulgaris”, vogliono scoprire 
cosa si nasconde dietro questo appassionante mondo dell"‘intelligenza ar¬ 
tificiale" e che allo stesso tempo non vogliono impegnare cifre considere¬ 
voli. 

Il prezzo infatti è ciò che strizza più l’occhiolino ma non ci dobbiamo ferma¬ 
re qui, la '57 è un vero, seppur piccolo, computer. 

Presto però tutti, chi prima chi poi, ci si accorge con rammarico dei limiti che 
detta macchina ci impone e allora cominciano i pensieri. 

C’è chi pensa subito di passare alle sorelle maggiori e chi invece, come me, 
decide di guardarci un po’ "dentro". 

Appaiono così, un po’ su tutte le riviste del ramo, vari suggerimenti e varie 
modifiche, ma quasi tutte si limitano a usarla né piu né meno come timer in¬ 
telligente. Certamente io non ho scoperto l’America, chissà a quanti prima 
di me sarà venuta l’idea, ma ho tentato di "nobilitarla” dandole la possibilità 
di colloquiare, o meglio "ascoltare” il mondo esterno. 

Di darle un ‘bus’ più o meno standard nemmeno a pensarlo e allora la clas¬ 
sica lampadina: perche non interfacciare la tastiera? Da qui ogni sorta di 
immondo pensiero, dalla possibilità di registrare i programmi su nastro 
magnetico, per i più bravi e i più zelanti, o su banda perforata, per i più pigri 
come me, e via sulla strada deH'implementazione di giochi o cose più utili. 
Quello che vi presenterò, più che un progetto finito e a sé stante è una 
strada nuova su cui sbizzarrirvi con la vostra splendida ‘57. 

I contatti delia tastiera sono perfettamente visibili nello spaccato di figura 
1A e sono “quantificabili” nelle lettere dame assegnate, in modo assoluta- 
mente arbitrario, in calce a detta figura. 
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figura 1B 
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microconnettore 
(femmina) 15SB 
"Cannon” 15 poli 


1 = 7 
2=2 
3=3 
4=4 

5 = 5 

6 = 6 

7 = 7 

8 = 8 

9 = n.c. 

10 = n.c. 

11 = A 

12 = B 

13 = C 

14 =D 

15 = E 


figura 1C 

Collegamenti consigliati per l'utilizzo del connettore “ Cannon " 
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Interfacciamo la TI-57 


La relazione che lega detta matrice con i simboli risultanti è data dalla figu¬ 
ra 1B, che si rifa per l’appunto al tastierino della macchina in questione; il 
tutto elegantemente realizzato con micro connettori Cannon, acquistabili 
alla GBC e abbastanza “salati”, a 15 poli come da figura 1C e relative foto. 



A questo punto la domanda: cosa ne facciamo? Ai più bravi nessuna rispo¬ 
sta, o hanno già snobbato tutto quanto o hanno già deciso cosa fare, agli 
altri, forse non meno bravi ma più curiosi, illustrerò parte della mia mirabo¬ 
lante costruzione. 

L’idea base è quella di far corrispondere a ogni tasto un ben determinato 
byte di sette bit, otto nel caso si inserisca un particolare bit di controllo, in 
modo da poter memorizzare o manipolare il dato con relativa facilità. 
Infatti, se osserviamo di nuovo la figura 1B notiamo che, per ottenere, ad 
esempio, il carattere ‘8’ si deve congiungere la riga n. 7 con la colonna ’C’, 
come pure per ottenere la funzione ‘LRN’ la riga n. 2 con la colonna ‘A’. 
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colonne righe 


Interfacciamo la Tl-57 


Ci si rende subito conto delle difficoltà di manipolare i dati sotto questa 
forma e allo stesso tempo della macchinosità della cosa, in quanto utiliz¬ 
zando la tastiera a questa maniera arriveremmo al limite della praticità con 
un byte lungo addirittura 40 bit. Sono perciò ricorso a switches elettronici 
di tipo C-mos comandati da decodifìche binario-decimale attraverso op¬ 
portuni adattamenti dell'informazione trattata. 

Semplice eh? ma se osservate lo schema di figura 2 tutto sarà ancora più 
semplice e chiaro! 



figura 2 

Zoccolature degli integrati a pagina seguente. 
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CONNECTION 01AGR AM 
DIR (TOP VIEW) 
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SN 7442 

LOGIC SVM0OL 
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V C C * Pi" 16 
GNO * P.n a 


segue figura 2 
Zoccolature degli integrati. 


Gli integrati X, e X 2 selezionano le righe mentre X 3 e X 4 , ovviamente non 
completamente utilizzati, selezionano le colonne. L'informazione viene in¬ 
fettata dai pin A0.A1 ,A2,A3 per le righe, e dai pin B0,B1 ,B2 per le colonne; 
è quindi decodificata da X 8 e X 9 e preparata daX 6 , X 6 , X 7 che ne inverte il li¬ 
vello logico. Possiamo inoltre notare i pin S1,S2,X,Y,Z che, transitati attra¬ 
verso X 7 e quindi ribaltati nel livello logico, diventano rispettivamente 
CI ,C2,C3,C4,C5 per comandare piccoli led che ci indicheranno, nel caso di 
CI e C2, l'assenza di qualsiasi dato e, nel caso di C3,C4,C5 attivati, della 
presenza di overflow. 

Arrivati sin qui, il nostro obiettivo è pressoché raggiunto: infatti possiamo 
dare in pasto alle fameliche decodifiche il byte 1110110 che subito appa¬ 
rirà nel display della nostra beneamata ‘57 il carattere ‘8’. 

Ovviamente il primo semibyte da 4 bit corrisponde all’indicazione binaria 
relativa, o meglio BCD, della riga (nell’esempio la n. 7) e il secondo semiby¬ 
te, di soli 3 bit, corrisponde all'Indicazione BCD della colonna (nell’esem¬ 
pio la ‘O ricordando che vale la seguente relazione: 

A = 1 
B = 2 
C = 3 
D = 4 
E = 5 

Ora entra in gioco la vostra fantasia e tutta l’ingegnosità di cui disponete; io 
personalmente ho utilizzato il byte così ottenuto per registrare i program¬ 
mi su banda perforata leggendo l’informazione con comuni fotoresistenze 
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che pilotavano i relativi transistori, ma non ci si deve fermare qui: volendo 
si può trasformare l'informazione da parallela a seriale, registrare quindi i 
dati su nastro magnetico, addirittura trasmetterli e così via sino al limite 
della nostra immaginazione: l'importante è avere la coscienza di fare qual¬ 
cosa per restare al passo di questo sviluppo tecnologico travolgente e di 
essere entrati in un mondo che ancora a molti fa paura, ma che sarà il pane 
di molti tecnici di domani. c5 

TflUTH TABLE a. 



B 0 £>ì 

6 A B c D e 8 ■» 

L t L 

H t. L 

L M t. 

M H L 

L l H 

H L M 

H H H 

HMLMMMHH 

mmmlhhmh 

MHHMl MHM 

MHHHHL HH 

HMHHHHHL 


H - HlGM Voll»V« L*v«M 

l * lOw voiua* l**#! 


Un ultimo sguardo ora alla figura 3 che rappresenta la tavola della verità 
del byte di ingresso utile per la codificazione dei caratteri usati e per l’uti¬ 
lizzo degli indicatori CI (0 nel primo semibyte), C2 (0 nel secondo semi¬ 
byte), C3 (overflow nel primo semibyte), e C4,C5 (due condizioni di over- 
flow per il secondo semibyte). 

Dalle foto, inoltre, per le quali va un particolare ringraziamento all’amico 
Claudio Gatti, notiamo i particolari del montaggio dell'interfaccia e della 
modifica alla TI57. ## ## >*$#*###** ### #######* # #*#* >» 
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CI DIGITAL COMPUTER 



SCHEDA MICROCOMPUTER 
basata su 

microprocessore Z80/A 

- linguaggio Basic 

- Tastiera alfanumerica - 40 tasti 

- Uscita video universale 

- Presentazione 

32 caratteri per 24 righe 

Memoria R.A.M. disponibilità 1 K 
Sistema operativo su EPROM da 4 K 
Entrata e uscita per registratore 
Alimentazione 5 Volt stabilizzati 
Connettore posteriore 
per future espansioni 
Sono in allestimento 
le espansioni di memoria 
da 8 e 16 Kbit 


CONOSCETE I NOSTRI FALCONKIT? 


FK 100/C - 


Car stereo booster 
30+30 W 


FK 180 
FK 190 


FK 110/C 
FK 120/C 
FK 130 
FK 140/C 
FK 150 


FK 150/C - 


FK 160/C 
FK 170 


Antenna portabollo 
Led Vu-meter per auto 
Led Vu-meter profess. 
Antifurto per auto 

Sirena elettronica 
con altoparlante 10 W 

Sirena elettronica 
con contenitore 

Luci psichedeliche per auto 
Luci psichedeliche profess. 


FK 200 
FK 210/C 
FK 220 


FK 230 
FK 250/C 
FK 260 
FK 270/C 
FK 280/C 


Luci stroboscopiche 
Amplificatore mono 7 W hi-fi 
Amplificatore mono 15 W hi-fi 
Contagiri per auto a led 

Orologio digitale 
a display giganti 
Preamplificatore stereo hi-fi 
Lampeggiatore con relè 
Metronomo elettronico 
Timer 


Alimentatore stabilizzato 

(utilizzabile in particolare per il Cl) 


N.B. - gli articoli ... /C vengono fomiti completi di contenitore 


Potete trovare i nostri FALCONKIT presso tutti 
i migliori negozi di elettronica della Vostra citta. 
Saremo lieti di fornirvi i nominativi. TELEFONATECI! 


Ulcon 






s.n.c. Via Samoggia, 68 - Reggio Emilia - TeL (0522) 34974 









Tutto quello 

che avreste voluto sapere 

.... sulle EPROM 

(e che non avete mai osato chiedere) 


Paolo Sinigaglia 


Non preoccupatevi, stavo scherzando; poca teoria e molti 
fatti (o quasi). 

Tanto per non smentirmi, inizierò parlando di tutto salvo che 
delle EPROM. 

Viene chiamato RAM (Random Access Memory cioè memoria ad accesso 
casuale) qualunque elemento che contenga un certo numero di circuiti bi- 
stabili in grado di contenere una cifra binaria (Oo 1) ciascuno, in cui i bista- 
bili non siano accessibili direttamente ma solo tramite indirizzamento. 
Lo so che non si capisce niente, ma non è colpa mia; mettiamola cosi: una 
RAM è un circuito a cui oltre a dire di memorizzare qualcosa, dobbiamo an¬ 
che dire dove memorizzarla, cioè in quale parte della memoria. 

Tutto chiaro? Bene, e le ROM? ROM non vuol dire, come qualcuno può 
aver pensato...Random Occess Memory, bensì Read Only Memory (me¬ 
moria a sola lettura). Suona un po’ reazionario una memoria che ricorda 
sempre il passato senza possibilità di cambiamento, ma in qualche caso (a 
dire il vero in molti casi) possono anche essere utili, il concetto comunque 
non è molto diverso da quello delle RAM, si potrebbe dire che sono delle 
RAM il cui contenuto viene deciso al momento della fabbricazione e non 
può più venir cambiato (è sconsigliabile inventare le Write Only Memory, 
anche se sarebbero state comode a Nixon ai tempi di Watergate...). 
Dopo le ROM vengono le PROM (questo è facile e vuol dire davvero Pro- 
grammable Read Only Memory) e cioè memoria asola lettura programma- 
bile (sarebbe come dire che si può solo leggere ma anche scrivere). 

Il problema sta nel fatto che nelle PROM ogni bit, 1 o 0, è rappresentato da 
un fusibile all'interno dell’integrato; quando la PROM viene venduta (o 
comprata a seconda dei punti di vista) tutti i fusibili sono intatti; per mezzo 
di impulsi di tensione è possibile bruciare selettivamente alcuni dei fusibili 
ottenendo così la programmazione. Il vantaggio delle PROM rispetto alle 
ROM è che l'utente può programmarle da solo riducendo (molto) i costi 
per piccole quantità; rispetto alle RAM il vantaggio sta nel fatto abbastan¬ 
za ovvio che, una volta programmato, il contenuto della PROM rimane inal¬ 
terato anche se non è applicata l’alimentazione. Gli svantaggi sono due: la 
programmazione delle PROM è una faccenda lenta e, essendo chiaramen¬ 
te impossibile ricostruire un fusibile bruciato lungo un decimo di milllime- 
tro, è anche impossibile correggere un errore di programmazione. 
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... sulle EPROM! 


E le EPROM? direte voi 

Calma, adesso ci arrivo. 

EPROM sta per Erasable Programmable Read Only Memory cioè memoria 
a sola lettura, scrittura e cancellazione (si, sono d'accordo, è una cosa as¬ 
surda ma non è colpa mia). 

Nelle EPROM ogni cella di memoria è costituita da un mosfet in cui, oltre a 
un gate “normale” (vedi figura 1), esiste un gate "fluttuante”. 

STORAGE CELL CROSS SECTION 



U CROSS SICTION 


Hi 


tlOAtltiC SOO»CI Vys 
G*l( 

tei SCH(V«TIC tYMBOl 


figura 1 

Sezione trasversale del mosfet che costituisce la cella di memoria di una EPROM (a sinistra) e simboli 
della EPROM (a destra). 

Al centro della sezione si vedono il gate "normale" e quello fluttuante, indicato tratteggiato nella rappre¬ 
sentazione schematica. 


La programmazione viene ottenuta imprigionando delle cariche negative 
(elettroni nella fattispecie) nel gate fluttuante per mezzo di impulsi 
elettrici. 


STORAGE CELL THRESHOLD SHIFT 



VOLTAGE ON GATE OF CELI 


figura 2 

Grafico della corrente circolante nel mosfet al variare della tensione applicata al gate "normale". 

Si veda come la tensione di soglia nella cella non programmata (VrJ s/a molto inferiore che non nella cel¬ 
la programmata (Vt 0 ). 
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... sulle EPROM! 


La presenza delle cariche nel gate fluttuante modifica le caratteristiche 
del mosfet nel modo indicato in figura 2; la tensione di threshold, la tensio¬ 
ne minima da applicare al gate normale per ottenere la conduzione, passa 
da un valore nettamente inferiore a quello indicato come sense threshold 
a uno superiore. Applicando al gate la tensione di sense threshold è possi¬ 
bile stabilire, in base alla conduzione del canale, se la cella in questione è 
programmata o meno. Poiché il gate fluttuante è circondato da Si0 2 che è 
un ottimo isolante, le cariche possono rimanere intrappolate per tempi 
molto lunghi. In effetti l’unico modo con cui è possibile liberare le cariche 
dal gate fluttuante è fornire loro un’energia sufficiente a superare la bar¬ 
riera costituita dall’ossido di silicio. Questa energia può venire fornita me¬ 
diante l'illuminazione con luce della stessa lunghezza d’onda, di solito nel¬ 
la banda dell’ultravioletto, per dovere di cronaca devo dire che esistono 
anche dei circuiti detti EEPROM o E 2 PROM che sta per Electrically Erasa- 
ble eccetera, Cioè PROM concellabili elettricamente, che assomigliano 
molto alle EPROM ma che possono essere cancellate mediante impulsi 
elettrici invece che con l’ultravioletto. Si tratta di circuiti costruiti con una 
tecnologia relativamente nuova e non sono ancora riuscito a saperne qua¬ 
si niente; pazienza, non dum matura est. 

Ma allora come si usano queste EPROM? lo propongo di vedere separata- 
mente i seguenti punti: come si fa a leggere, a cancellare, a programmare 
le EPROM più diffuse e infine quali circuiti usare per farlo. Sia ben chiaro 
che questa scaletta è solo una mia proposta e voi siete padronissimi di non 
essere d’accordo con questa suddivisione, non che la cosa mi interessi 
molto, anzi, a dirla tutta, non mi interessa affatto. Quindi, per dimostrare 
che non mi interessa neanche la scaletta, incomincio subito dal secondo 
punto e cioè dalla CANCELLAZIONE o, come dicono quelli che hanno stu¬ 
diato, ERASING. 

Cancellare una EPROM 
è la cosa più facile 
del mondo, quello 
che è più difficile è 
impedire che si can¬ 
celli da sola... 

In figura 3 avete sot¬ 
to il naso un grafico 
del tempo di cancel¬ 
lazione in funzione 
della lunghezza d’on¬ 
da a parità di illumi¬ 
nazione. 


N-CHANNEL EPROM 
PHOTO-ERASE CHARACTERISTIC 


4.3 aV 3.2 eV 



figura 3 

Il tempo di esposizione necessario a cancellare una EPROM a canale N (tratto continuo) o a canale P 
(tratteggiato) è qui riportato in funzione della lunghezza d'onda della luce usata a parità di illuminazione. 
Anche se ovviamente non si può vedere dal grafico, il tempo di esposizione è inversamente proporziona¬ 
le all'illuminazione. 
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... sulle EPROM’ 


Il grafico tratteggiato vale per le EPROM a canale P mentre l’altro vale per 
quelle a canale N. Prenderemo in esame solo le EPROM a canale N perché 
sono le piu diffuse (ma esistono anche le altre). Vediamo dal grafico che il 
tempo di cancellazione aumenta all’aumentare della lunghezza d’onda fi¬ 
no a circa 3.800À, per X superiori il tempo necessario aumenta molto rapi¬ 
damente e, per X > 3.900À circa non si ha cancellazione qualunque sia il 
tempo di esposizione e l'illuminazione (è comunque sconsigliabile cerca¬ 
re di verificarlo mettendo la EPROM in un forno a infrarossi); il tempo 
d’esposizione è invece inversamente proporzionale all’illuminazione (che 
a sua volta è inversamente proporzionale al quadrato della distanza dalla 
sorgente di luce). L’ovvia deduzione è che per cancellare è necessario 
usare una lampada che emetta luce con X < 3.800À. Il modo migliore per 
ottenerla è di usare una lampada a vapori di mercurio non filtrata (sono 
inutili a questo scopo le lampade cosiddette “solari’’ o quelle a “luce nera” 
poiché non emettono quantità sufficiente di ultravioletto lontano), vanno 
invece benissimo le lampada germicide usate per la sterillizzazione degli 
strumenti chirurgici. 

ATTENZIONE: l'ultravioletto lontano è pericoloso; un’esposizione prolun¬ 
gata può provocare tumori alla pelle, guardare direttamente la lampada in 
funzione può dare danni irreparabili agli occhi. È necessario montare la 
lampada in un contenitore chiuso in modo che si spenga se viene aperto. 
Adesso che ho compiuto II dovere di mio bravo cittadino avvertendovi dei 
rischi, posso tirare avanti. 

Il prossimo problema è accendere la lampada, non starò a dilungarmi e vi 
lascio alle prese con figura 4 (è un po’ sibillina ma non difficile). 



figura 4 

Se la lampada, il reattore e lo starter sono interi e se c'è tensione si dovrebbe accendere. 
/, è l'interruttore di sicurezza per chi si preoccupa dei propri occhi. 


Il prossimo è più complicato: per quanto tempo bisogna lasciare l’EPROM 
sotto la lampada? Peravere una cancellazione completa con una lampada 
a vapori di Hg è necessario avere una densità di energia di 15 Ws/ cm 2 il 
che significa che, se la lampada è cilindrica di potenza P, lunghezza L e la 
EPROM (o le EPROM) è a distanza D dal suo asse, il tempo T necessario al¬ 
la cancellazione è dato dalla formuletta: 

T = 30-tt-L-D 
P 
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dove L e D sono espressi in centimetri. P in watt e T in secondi(ricordo che 
tt=3,14... bisogna proprio dirvi tutto?). Prima dicevo che il problema non è 
stato cancellare le EPROM quanto evitare che lo facciano da sole; forse ho 
esagerato uri po’, ma il problema esiste davvero; da figura 5 si vede che, sia 
la luce solare, sia quella dei normali tubi fluorescenti contengono radiazio¬ 
ni con lunghezza d’onda inferiore alla soglia dei 3.800 À. Questo significa 
che se non si copre (ad esempio con un pezzo di scotch) la finestrella delle 
EPROM, a lungo andare possono venir cancellate dalla luce esterna. A tito¬ 
lo puramente indicativo, il tempo di cancellazione con un'esposizione di¬ 
retta ai raggi solari è dell’ordine delle ore, con le lampade fluorescenti è di 
qualche giorno. Anche se la finestrella è ben coperta, le EPROM non ten¬ 
gono i dati all’infinito per agitazione termica, o per azione della radioattivi¬ 
tà di fondo o dei raggi cosmici; sembra poco, e infatti è poco: secondo i da¬ 
ti della INTEL sono necessari mediamente dieci anni perchè una EPROM 
tenuta in condizioni normali perda dei dati. 

SPECTRAL ENERGY CONTENT OF THE SUN 
AND COOL WHITE FLUORESCENT LAMP 



«aura 5 WAVELENGTH (A) 

Contenuto spettrale della luce solare e della luce delle normali lampade fluorescenti. 

Come si vede, una parte di ambedue ha \ inferiore ai 3800 A e può quindi causare la cancellazione di una 
EPROM. 


Passiamo ora al secondo punto (che era poi il primo) e cioè la lettura dei 
dati programmati nella EPROM; facciamo prima un discorso generale e 
passeremo poi a esaminare in dettaglio le due famiglie di EPROM attual¬ 
mente più diffuse: la serie 2704/ 2708 e la serie 2758/ 2716/ 2732 della IN¬ 
TEL ed equivalenti. 

Si può dire che, in generale, i terminali di una EPROM si possono dividere 
(salvo che durante la programmazione) in quattro gruppi: terminali di ali¬ 
mentazione, di abilitazione, di address (indirizzo) e di output (uscita). Per 
quanto riguarda l’alimentazione, in generale i terminali sono indicati con 
una sigla che comincia per "V”, di solito Vcc indica l’alimentazione a 5V po¬ 
sitivi e V ss la massa; queste sono le uniche tensioni di alimentazione ne¬ 
cessarie per le EPROM della famiglia della 2716; per quelle della famiglia 
della 2708 eper la maggior parte delle altre, sono necessarie diverse altre 
tensioni (—5, +12, —12 V, eccetera) di alimentazione. Per alcuni di questi 
circuiti è NECESSARIO che le alimentazioni siano applicate e rimosse si¬ 
multaneamente per evitare di fare un arrosto di eprom (di cui vanno parti- 
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colarmente ghiotti i Rivenditori...). Saltiamo per un attimo i terminali di abi¬ 
litazione e passiamo a quelli di address. Questi ultimi sono normalmente 
indicati come AO, Al, A2, A3 eccetera; a cosa servono? La cosa è semplice 
(abbastanza): servono a dire alla EPROM quale delle celle di memoria il nu¬ 
mero binario ottenuto scrivendo uno dopo l’altro i livelli logici che si devo¬ 
no applicare ai terminali di address per selezionare quella data cella di 
memoria. 

Facciamo un esempio che è meglio: consideriamo una EPROM che abbia 
quattro ingressi di address; la cella indirizzata dando agli address i se¬ 
guenti livelli logici: 

AO = 1 

Al =0 

A2 = 1 

A3 = 0 

sarà indicata come cella numero 5 poiché scrivendo nell’ordine i livelli di 
A3, A2, Al, AO otteniamo 0101 che in binario equivale a 5. Sono tentato di 
non dirvi nemmeno cosa sono i terminali di output poiché mi sembra al¬ 
quanto ovvio; sono normalmente indicati come 01, 02, 03, eccetera 
(l’avevate già indovinato vero?); quando la EPROM è abilitata, il livello logi¬ 
co degli Output ci da il contenuto della cella indirizzata. 

Bene, mi sembra che fino a qui sia tutto chiaro, il prossimo punto sarà inve¬ 
ce un po'più impegnativo; infatti è abbastanza difficile generalizzare per 
ciò che riguarda i terminali di abilitazione perché il loro funzionamento va¬ 
ria tra i vari tipi di EPROM; esamineremo quindi nei dettagli le caratteristi¬ 
che di due soli circuiti: la 2716 e la 2708, per ciò che riguarda gli altri inte¬ 
grati di queste famiglie le cose vanno ancora bene perché le caratteristi¬ 
che sono quasi identiche, per gli altri bisogna arrangiarsi per analogia. 
Spero che siate d’accordo sul fatto che una descrizione dettagliata di tutti 
i tipi di EPROM esistenti sul mercato richiederebbe un libro piuttosto che 
un articolo. 

In figura 6 abbiamo le prime pagine dei Data Sheets della 2708 e della 
2716; esaminiamo prima figura 6a: nella 2708, oltre ai piedini di address e 
di output, abbiamo dei piedini indicati come V S s, V C c, Vbb e Vuu, PROGRAM e 
CSI WE. Per le alimentazioni la cosa è semplice: V ss va a massa, v cc a +5 V, 
Vbb a —5 V e Vdd a +12 V; dalla tabella riportata nella stessa figura si vede 
che, in condizione di lettura, anche il piedino PROGRAM va connesso a 
massa. È rimasto il piedino CSI WE che permette l’abilitazione e la disabili¬ 
tazione della memoria: quando CSI WE è a livello logico basso la memoria 
è abilitata, quando è alto i pin di output sono in condizione di alta impen¬ 
denza (Hi-Z) e cioè si comportano quasi come se fossero scollegati (dalla 
tabella delle caratteristiche in figura 7a apprendiamo che la corrente di fu¬ 
ga (Output Leakage Current) Ilo massima è di 10 pA). 

D’accordo, adesso vedo di andare più svelto... Perla 2716 (figura 6b) le co¬ 
se sono simili salvo che abbiamo un’unica tensione di alimentazione a 5 V 
che, in lettura, va applicata ai pin Vcc 6 Vpp e che esiste la possibilità, met¬ 
tendo a livello alto il pin PD/ PGM, di entrare nello stato "power down” in 
cui (figura 7b) la corrente di picco assorbita scende da 105 mA a 30 mA e in 
cui gli output sono in Hi-Z. 

Bene, ci siete ancora tutti? Speriamo... 

Tutto quello che ho detto fino ad ora è vero (chi mai potrebbe dubitarne), 
ma si può applicare solo in condizioni statiche, cosa succeda nel momento 
in cui applichiamo gli stati logici ai piedini di address e di abilitazione non 
lo so e non c’è modo di saperlo; infatti, come si vede in figura 8, è necessa- 
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PIN CON FIGURA TION 


»c 

' 24 


*.c 

I 23 

3*. 

‘iC 

j 22 

D A9 ;U 


* 7\ 

H*. 

•>c 

4 20 

I]cSA« 

*.c 

® 2708.3704 1* 

ID Hx> 

*.c 

7 )# 

3 PROGRAM 

*.c 

8 17 

13 07 "-'sa; 


9 18 


«■c 

IO »S 

Dos 

■’iC 

’> 

Do. 

A.C 

12 ’J 

Do, 


Noni •IN 32 MVST 86 CONNECTEO 
TO Vs$FO" 'H£ 2704 


BLOCK DIAGRAM 

n*i 4 «fnjT 
>J0 0/ 



PIN NAMES 


* 0*7 

AOORESS'NPurs 

0 . 0 , 

data ouTPurs/iNPurs 

flVrE 

CHIPSEUCT-ARire ENABlE INPUT 



2716 2732* 



IRefer to 273? 
data sheet for 
speci fications 


PIN NAMES 


AO 0 RÌJS 1 S 
CHIF ÉNÀaa PROGRAM 

OuiFyi' fSAgit _ 

OoTPUTS_ 


PIN CONNECTION DURING READ OR PROGRAM 


MQOE 

«EAO 

ocseuct 

PROGRAM 


DATA I 0 
9 11. 

I>17 

°OUI _ 

HIGH IMPEOAUCE 


PIN NUM 8 EB 

AOORESS 

INPUTS 

' 8 . Vu . PROGRAM 

22 73 _ 1 ? 18 

* 1 * GND GND 

OON'T CARE • CNO GNO 

a,* GNO Piaste 

2 «v 




BLOCK DIAGRAM 



figura 6 , 

Prima pagina dei Data Sheets delle EPROM 2708 (a) e 2716 (b) della INTEL. 

Dalla figura si ricavano collegamenti, alimentazioni e schema di principio di queste EPROM che ho scelto 
come rappresentative delle rispettive famiglie, certamente tra le più diffuse. 
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Absolute Maximum Rating** 

Temperature Under Bias. _2S°C to ♦85°C 

Storage Temperature. -65’C 10*125*0 

Voo wi,h Respect to V BB . *20V to -0.3V 

V^c V SS With Respect to V B0 . *15Vto-0.3V 

All Input or Output Voltage* With Respect 

_to V aB During Read. »15V to -0.3V 

CS/VVE Input Wnh Respect to Vbb 

During Proritamminq . *20V to -0.3V 

Program Input Wnh Respect to V B b . *35V to -0 3V 

P©v»er Dissipano".. jjjyy 


DC and AC Operating Conditions During Read 


NOTE: 

1) Vbb deve essere applicata per prima 
e rimossa per ultima. 

2) Valori tipici per T A =25°C 

3) la dissipazione totale non può es¬ 
sere calcolata moltiplicando le 
tensioni di alimentazione per le 
correnti massime 



READ OPERATION 

D.C. and Operating Chara?taristics 



Absolute Maximum Ratings* 

Temperature Under Bias. 

Storage Temperature . . . 

AM Input or Output Vohages wth 
Respect ro Giouoo . . 
VppSupps Vo'tdj-, wth Respect 
ri’ G'Ound Duitisg Program . 


. -10 c c to + 80 ”C 
-65° C I0-O25C 

. +6V to -0.3V 

. *26.5V to -0.3V 


NOTE: 

1) Vcc deve essere applicato prima di Vpp 
e rimosso dopo (o contemporaneamente) 

2) La corrente totale è Vcc+Vpp^ 

3) Valori tipici per T A =25°C 


DC and AC O.nerating Conditions During Read 



2716 

2716-1 

2716-2 

Temperature Range 

O'C - 70 f C 

0 c C - 70' C 

0C-70C 

Vcc Power Supply* 1 ' 2, 

5V i S % 

5Vt 10% 

5V r 5% 

Vpp Power Supply 

V CC 

V C c 

~ V, c ~1 


READ OPERATION 

D.C, and Operating Characteristics 


Symbol 

Psrameter 

Limiti 

Unii 

Conditions 

Min. 

Tv,™ 

Max. 

•li 

Input Load Current 



10 

pA 

Vin = 5 25V 

•lo 

Output Leakage Current 



10 

pA 

V 0 UT = 5-25V 

Ippt ' y ‘ 

Vpp Current 



5 

mA 

Vpp - 5 25V 

ICC,»' 

Vcc Current (Standbvl 


10 

25 

mA 

lo 

z 

> 

B 

ICC2 13 ' 

Vcc Current (Active) 


57 

100 

mA 

OE = CF = V ti 

Viu 

Input Low Voltage 

-0.1 


08 

V 


V IH 

Inp-t H,gr> Voltage 

20 


Vcc-»’ 

v 


Vot 

Output Low Voltage 



0.45 

V 

Iq, - 2 1 mA 

< 

o 

X 

Output H.gh VoPage 

2,4 




■Oh 5 -400 il A 


figura 7 

Seconda pagina dei Data Sheets; e vi ho anche tradotto le note! 
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rio un certo tempo perché dopo l’applicazione degli indirizzi i dati in uscita 
siano validi (Tacc = 450 ns max) o perché dopo che CSI WE sia diventato 
basso gli output escano dallo stato Hi-Z (Tco= 120 ns max) e, ancora, per la 
2716 è necessario un certo tempo (Tacc 2 = 450 ns max) per uscire dallo 
stato di power down(o Standby che è io stesso). 

A. C. Characteristics 


Symbol 

Parameier 

2708-1 Limiti 

Min. Typ. Max. 

2708, 2708L, Limiti 

Min. Typ. Max. 

Unii» 

*ACC 

Address to Output Delay 


280 

350 


280 

450 

ns 

tco 

Chip Select to Output Delay 


60 

120 


60 

120 

ns 

lOF 

Chip Deselect to Output Float 

0 


120 

0 


120 

ns 

tQH 

Address to Output Hold 

0 



0 



ns 


CAPACITANCE 1 ' 1 T A = 25°C, I = 1 MHz 


Symbol 

parameter 

Typ. 

Max. 

Unit. 

Conditioni 

C|N 

Input Capacitance 

4 

6 

pF 

V|„ - ov 

Cout 

Output Capacitance 

8 

12 

PF 

VouT - 0V 


Nota: 1. Thi» parametar hi pedodlcally «ampted and li not 100% tejted. 


A.C. TEST CONDITIONS: 

Output Load: 1 TTL gate and Cl 31 100 pF 
Input Rise and Fall Times: <20 ns 
Timing Measurement Reference Levets: 0.8V and 
2.8V for Inputs; 0.8V and 2.4V for output*. 
Input Pulse Lewels: 0.65V to 3.0V 


Waveforms 


ADO RE SS 


CS.fi l 




figura 8 

Caraneristiche della 2708 in corrente alternata (in lettura); perla 2716 le caratteristiche sono uguali alla 
2708L, per la 2716-1 sono uguali alla 2708. 


Abbiamo così finito di parlare di come si legge una EPROM, a questo punto 
si impone un doppio salto condizionato: se avete capito tutto fino a qui, 
prendetevi un attimo di respiro dalla mattonata e leggete il seguito su cq 
elettronica di aprile; in caso contrario, se pensate che la colpa è mia, pian¬ 
tate tutto li e passate al prossimo articolo cosi risparmiate tempo (il tempo è 
denaro e il denaro sono soldi), se invece pensate che la colpa sia vostra al¬ 
lora dovete leggere da capo (se pensate che ne valga la pena).#***# 
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Bozza di progetto 

per un 

VFO computerizzato 

ing. Gianni Becattini 


Sul numero 11/81 di cq elettronica è comparso un interessante 
articolo sui generatori dì frequenza PLL, encomiabile per la sua 
chiarezza. 

La lettura di questo scritto mi ha fornito lo spunto per un proget¬ 
to di massima di un VFO controllato a microprocessore. Anche 
se si tratta di uno studio essenzialmente teorico, l'analisi pre¬ 
ventiva delle varie sezioni è stata ugualmente molto curata e 
sono certo che chiunque lo desideri possa facilmente tradurre 
in pratica questo interessante circuito. 

Descrizione funzionale del prodotto finito 

L’ipotetico VFO è racchiuso in un contenitore di piccole dimensioni. 

Il frontale potrebbe essere quello di figura 1. 


per 

OM 


figura 1 
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Bozza di progetto per un VFO computerizzato 


Sul pannello abbiamo alcuni led, un display, alcuni pulsanti, un deviatore, 
oltre l’interruttore di accensione, e una manopola per la sintonia. 

I tasti, oltre che perle funzioni, servono anche per la impostazione di quan¬ 
tità numeriche. 

Esaminiamoli nel dettaglio: 

F UP (Frequency up)-lncrementa le cifre sul display e la frequenza di uscita 
del VFO. La velocità con cui avviene la variazione è dapprima lenta e poi via 
via crescente. Col deviatore AUTO in posizione ON la ricerca continua au¬ 
tomaticamente anche quando si abbandona il tasto e si arresta quando 
perviene un segnale dal ricevitore. 

F DWN (Frequency down)-Come il precedente ma a decrementare. 

B UP, B DWN (Band up, Band down) come i precedenti ma con azione sul¬ 
le sole cifre più alte del display, per effettuare la commutazione di gamma. 
STO (Store)-Permette di memorizzare una di 99 frequenze a piacere. Si 
preme STO seguito dal numero della memoria corrispondente. Le memo¬ 
rie da 0 a 9 sono indicate come 00, 01.09. L’impostazione dei numeri av¬ 

viene con gli stessi tasti funzione. 

RCL (Recall)-Si usa come il precedente e serve per richiamare una qual¬ 
siasi delle frequenze precedentemente memorizzate. Con alcuni accorgi¬ 
menti circuitali, che vedremo dopo, è possibile memorizzare oltre alla fre¬ 
quenza anche il modo di ricezione (AM/ FM/ LSB ecc.). 
EXPLORE-Esplora la banda, in su e in giù, compresa tra i valori di frequen¬ 
za registrati nelle memorie 01 e 02. Se è stato inserito l'AUTO si ha l’arresto 
per circa due secondi su ogni stazione incontrata nella esplorazione. 
L’EXPLORE viene disattivato premendo un tasto qualunque. 
SPEED-Viene usato per variare il rapporto di demoltiplica della manopola 
rotante e deve essere seguito da 1, 2 o 3 che corrispondono a: 

1 - un giro = 2.500 Hz (step 100 Hz) 

2 - un giro = 25 kHz (step 1.000 Hz) 

3 - un giro = 250 kHz (step 10 kHz) 

Se invece di battere 1,2 o 3 si batte SET, una serie di cifre e SET di nuovo è 

possibile prefissare uno step diverso (entro limiti preassegnati) e tutti i led 
dell'Indicatore di rapporto (i tre led segnati ONE TLIRN=) si spengono. 
LOCK-Disabilita la tastiera e la manopola rotante finché non si preme 
ancora LOCK. 

SET-Consente lo spostamento su una frequenza assegnata da tastiera. Si 
batte SET, la frequenza desiderata, che comparirà sul display, e SET di 
nuovo. 

I led indicano: 

LOCK - che la tastiera e la manopola sono disabilitate; 

EXPLORE - che il VFO sta compiendo esplorazioni; 

PREFIX - che è stato premuto un tasto dietro al quale si attendono altri ta¬ 
sti (STO - RCL - SET - SPEED); 

ON TURN= - indica il rapporto di demoltiplica scelto per la manopola. 
Tutti i led spenti indicano un rapporto non standard introdotto manual¬ 
mente da tastiera. 

II circuito 

Il circuito è molto tradizionale: uno Z-80 provvede comodamente a tutte le 
funzioni, come si può osservare dallo scherma a blocchi (figura 2). 

La parte PLL e divisore programmabile non è stata studiata nel dettaglio, 
esulando dall’oggetto proposto: non mancano tuttavia ottimi esempi sulle 
pagine di cq elettronica. 
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modulo base 



I riquadri tratteggiati indicano i moduli fisici di circuito stampato. Tutto il 
programma dovrebbe stare largamente in un solo k e si può usare quindi 
una 2708 come eprom (meglio se del tipo a una sola alimentazione). Due 
2114 compongono invece la memoria RAM che viene quindi anche essa 
ad essere di 1 k, più che sufficiente anche per espansioni future eventuali. 
La batteria in tampone non è necessaria, potendosi ricorrere alla soluzio¬ 
ne più semplice di prelevare una parte della tensione a monte dell'interrut¬ 
tore generale; in tal modo ovviamente la ritenzione dei dati è limitata al 
fatto che la spina sia inserita nella presa rete e che la tensione di questa ul¬ 
tima non venga a mancare. La soluzione più elegante, anche se più costo¬ 
sa, è quella di usare una memoria a basso consumo e una batteria in tam¬ 
pone. 

Le porte di uscita possono essere ottenute semplicemente con degli eco¬ 
nomici latch e quelle d'ingresso con dei tri-state buffer. Ne esistono tipi a 
basso consumo che possono essere montati direttamente sul bus senza 
bufferizzazioni. 
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8ozza di progetto per un VFO computerizzato 

Dato che tanto la memoria quanto PI/ 0 non sono molto estesi, non è ne¬ 
cessaria una completa decodifica dell’address bus per le selezioni. 

Il comando rotativo 

Il comando rotativo della sintonia è ispirato a quello comparso su cq 

elettronica (9/ 80). 

La manopola fa girare un disco che reca dei fori alla periferia per intercet¬ 
tare un raggio luminoso diretto a un fotodiodo. Nell’articolo citato si ricor¬ 
reva a un motorino in cc montato sullo stesso albero per identificare il sen¬ 
so del moto. Il nostro progetto di VFO tenta invece una strada diversa. 
Le coppie led/ fotodiodo sono due invece di una e due sono le file di fori di ¬ 
sposte come figura 3. 


figura 3 

La foratura del disco ottico 
0 = non foro 
1 = foro 


Si può constatare che facendo ruotare il disco in una certa direzione i led si 
accendono secondo la sequenza: 

.../. 

00 

01 

10 

11 

.../. 

e viceversa per la direzione opposta. 

È quindi come se avessimo un contatore binario a due bit che conta da 0 a 
3 rispettivamente per rotazioni in un certo senso (che fisseremo che sia 
quello orario) e da 3 a 0 per il verso opposto. Ecco quindi che diventa pos¬ 
sibile, a seconda dell'ordine crescente o decrescente delle combinazioni, 
risalire alla direzione del moto. Il problema è rappresentato dai passaggi 
da 11 a 00 e viceversa: il contatore ha ad esempio uscite 0,1,2,3,0,1,2.. e 
la sequenza crescente si arresta per ricominciare da zero ogni volta. Que¬ 
sti “ritorni indietro" o “salti" del conteggio possono tuttavia essere facil¬ 
mente interpretati dal programma. 

Facciamo alcune considerazioni. 

Chiamiamo: 

Lt il valore della lettura attuale dei led; 

Li- 1 il valore della lettura precedente; 

Paragonando Li e Lm posso determinare: 

a) se il disco è fermo; 

b) se il disco si muove; 

c) se il disco si muove in avanti; 

d) se il disco si muove indietro; 

e) se si è verificato un errore: ad esempio se si è passati dalla posizione 1 
alla 3 senza passare dalla 2. Ciò può avvenire per vari motivi come ad 
esempio una rotazione troppo veloce della manopola; come vedremo nel 
seguito è comunque una situazione che non si dovrebbe mai verificare. 
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Il caso a) è II più banale; il disco è fermo se Lt=Lt-i. 

I casi b), c), d) possono essere risolti con l’algoritmo riportato in figura 4. 



figura 4 


Sul caso e) non ci soffermiamo per ora. 

Ho provato a scrivere diversi programmi in Assembler Z-80 prima di arriva¬ 
re a quello che sto per illustrare che è certo il più veloce e il più interessan¬ 
te ai fini didattici e che vale quindi la pena di studiare nel dettaglio. 

Il programma MOTO 

Il programma non deve fare altro che risolvere la semplice funzione 

y = f(a,b,c,d) 

dove a,b,c,d sono le due coppie di valori Lt Lm e y può assumere i valori: 
y = 0 = disco fermo; 
y = 1 = disco avanti; 
y = 2 = disco indietro; 
y = 3 = errore. 

Invece di fare un programma che analizzi tutte le possibilità, si preferisce 
invece creare una tabella a 16 posti (i quattro ingressi a,b,c,d danno ap¬ 
punto 16 combinazioni possibili) dove per ogni combinazione possibile è 
registrata a lato la relativa y. 

La tabella è riportata in figura 5. 
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lettura 

1 

precedente 

bit 

0 

lettura attuale 
bit 

1 0 

i 

stato 

0 

0 

0 

0 

0 

FERMO 

0 

0 

0 

i 

1 

AVANTI 

0 

0 

1 

0 

3 

ERRORE 

0 

0 

1 

1 

2 

INDIETRO 

0 

1 

0 

0 

2 

INDIETRO 

0 

1 

0 

1 

0 

FERMO 

0 

1 

1 

0 

1 

AVANTI 

0 

1 

1 

1 

3 

ERRORE 

1 

0 

0 

0 

3 

ERRORE 

1 

0 

0 

1 

2 

INDIETRO 

1 

0 

1 

0 

0 

FERMO 

1 

0 

1 

i 

1 

AVANTI 

1 

1 

0 

0 

1 

AVANTI 

1 

1 

0 

1 

3 

ERRORE 

1 

1 

i 

0 

2 

INDIETRO 

1 

1 

i 

1 

0 

FERMO 

figura 5 

La tabella di decodifica; è possibile processare qua/siasi situazione in tempi molto brevi e con un pro¬ 
gramma molto semplice. 


Il programma MOTO (figura 6) combina assieme i 4 bit di Li e Ui e li usa co¬ 
me indirizzi per ricercare la relativa y in una tabella di 16 elementi. 


figura 6 
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Limiti 

Per curiosità ho voluto verificare i limiti di un complesso come quello ora 
descritto, almeno sulla carta, e mi sono calcolato approssimativamente la 
massima velocità che può essere impressa alla manopola perché non si 
abbiano “salti”, cioè condizioni di errore. Se: 

N = numero di divisioni del disco; 

T 8 = durata di un giro; 

T = intervallo di tempo tra due divisioni; 

g/m = velocità massima di rotazione espressa in giri al minuto si ha che: 

Tg= - 1 = _60 e T = _ 60 da cui g/ m = 

g/m g/m g/m-N N-T 

60 

Con T=50 ps (la routine riportata MOTO dura circa una ottantina di colpi di 
clock, che perTciok = 400 ns (fciock = 2,5 MHz) equivalgono a circa 30 gs) e 
N=50 come suggerito neH'articolo già citato, si ottiene quindi un massimo 
di circa 24.000 giri al minuto*. Molti si chiederanno perché ho espresso la 
velocità della manopola in giri al minuto: solo per rendere più intuitiva la 
portata del risultato; tutti abbiamo abbastanza presente questa unità di 
misura perché comunemente impiegata per i motori a scoppio! 

(*) Valore più che buono anche considerando, tra tolleranze e approssimazioni, di ridurlo al 25%. 


Il programma 

Non corre più il “lontano” 1975 e sono certo che oggi la maggior parte dei 
Lettori interessati può cavarsela senza aiuti per stendere il programma 
completo sulla base di quanto ho espresso fin qui. Anzi, potrebbe questa 
essere la buona occasione per iniziare a prendere pratica con i micropro¬ 
cessori. 

lo mi limito a presentare l’algoritmo base (figura 7). 



< ferma i 





\9 / 

scopri 

MOTO 

moltiplica per 
il valore 
di scala 



direzione 



n 

I 


foggi orna j laaatorna I 

lAT -Lf^LT 


figura 7 

(*) La lettura dei led è fatta per 
evitare segnalazioni di errore 
quando la manopola viene 
ruotata durante l’esecuzione 
di una funzione. 
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Bozza di progetto per un VFO computerizzato 


Uno dei grossi vantaggi del pp è quello di poter usare delle tabelle anche 
per convertire i dati del display o quelli del divisore programmabile (che di 
solito non usano lo stesso rango) o per effettuare qualsiasi variazione di 
scala. 

Sullo schema elettrico è stata inserita una porta ausiliaria EXT. Il suo scopo 
è quello di consentire al VFO di impartire comandi alle circuiterie esterne, 
come a quelle del ricevitore, in funzione ad esempio della banda selezio¬ 
nata e del modo di ricezione quando si desideri memorizzare anche esso. 

La meccanica 

La meccanica risulta essere oltremodo semplice. Riporto uno schizzo di 
come suggerisco sia realizzata (figura 8). 


;scheda A 


manopola 

g 


C 


pulsami e display 


disco scheda B 

/ed sensori 
/ e fotodiodi 


divisore programmabile 
/ e pll 

regolatore 
con dissipatore 


JL 


ri h 


piastra base 


figura 8 


Il disco potrebbe essere ottenuto fotograficamente: se ne guadagnereb¬ 
be in precisione. Un modo che potrei suggerire è quello di impiegare del 
Kodalith con la periferia a sporgere pressato tra due dischi in fibra. 

Conclusione 

Ritengo questa realizzazione molto interessante e mi dolgo che gli impe¬ 
gni quotidiani mi rendano impossibile di tradurla in pratica. Se ci fosse in 
zona qualche volenteroso con un po’di tempo libero per eseguire i disegni 
dei circuiti stampati, eventualmente con il mio aiuto, sarei ben lieto di com¬ 
pensarlo con tutto il materiale occorrente per costruirsi un esemplare pro¬ 
prio. # « « # # * # # # * s ***«##**<#### & * # * # # # » * « *= * « «= * « * 
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S & H s.n.c. 

PESCHIERA 

BORROMEO (MI) 
via 1° maggio 

Tel. 02 - 5472435 
Distributore per il Veneto 
Ditta ABACO 

f| f J'f/Y 40016 S.GIcKgio 
MI IIVJ V.Dante.l (BO) 
0Tel.(O51) 892052 
Vers. c/c postale re 11489408 
aggiungere L. 1.000 per spese p. 

f|^ 


[: 

r 

Z80A - 64KRAM - 4 floppy - 
I/O RS232 - Stampante ecc. - 
CP/M2.2 - Fortran - Pascal - 
ecc._ ' 

Terminale video 
tipo TVZ 

via Ognissanti - 7 
cap 30174 MESTRE 

Tel. 041-940330 
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GP User’s Group 


È stato formato un gruppo di utilizzatori di computers General 
Processor mod. T, con lo scopo di permettere scambi di idee, 
consigli, applicazioni, nonché di software. 

Gli interessati possono aderire all’iniziativa compilando la scheda ripro¬ 
dotta qui a lato con le informazioni sul tipo di sistema posseduto e interes¬ 
si circa il software, da inviarsi unitamente a una quota di lire 10.000, che 
servirà a coprire le spese postali e di stampa delle circolari e delle fotoco¬ 
pie dei manuali e istruzioni dei programmi inviati ai soci. 

Per usufruire della banca software del gruppo è sufficiente spedire un di¬ 
sco (8”) contenente i propri programmi, che andranno ad ampliare la ban¬ 
ca. Questo verrà poi ritornato con i programmi richiesti. 

È prevista la pubblicazione di un elenco dei programmi disponibili, che ver¬ 
rà periodicamente aggiornato. 

La banca software, data l'originale impostazione, si amplierà continua- 
mente, consentendo ai soci di usufruire di grandi quantità di programmi di 
ogni genere: software di base, utilità, archiviazione, statistica, matematica, 
varie, e anche giochi (non mancano gli scacchi). 

Ricordiamo ai soci come fare per accedere alla banca programmi: 

1 - prepara un disco contenente tutti i programmi che hai sviluppato o che 

possiedi (anche routines, utilità, ecc.); correda tutti i programmi per i 
quali lo ritieni opportuno, di un foglio con note, istruzioni (possibilmen¬ 
te fotocopiabile e scritto a macchina); 

2 - spedisci il tutto al Gruppo allegando le spese postali per il ritorno e 

l’elenco dei programmi che vuoi ricevere (per ora, fino alla pubblica¬ 
zione dell’elenco, ti verranno inviati tutti i programmi riguardanti i tuoi 
interessi, nei limiti di spazio del disco). 

IMPORTANTE: IL SISTEMA CHE GESTISCE LA BANCA PROGRAMMI LA¬ 
VORA CON DISCHI DA 8’’, PERTANTO I PROGRAMMI DEVONO ESSERE 
SPEDITI SU FLOPPY DI QUESTO FORMATO. 

Stiamo cercando anche qualcuno che volesse tenere la bancasu dischetti 
da 5”, gli eventuali interessati ci scrivano al più presto. 

G.P. USER’S GROUP 

via CASE SPARSE, 68 

34070 SAVOGNA D’ISONZO (GO) 

Saremo grati a chi ci fornirà nominativi di possessori di computers GP inte¬ 
ressati all’iniziativa. 
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GP User’s Group 
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01 A CAI il SPARSI-: fv « " 2-U7 l) S.'WiTiGivft Q'TiWZO (Ci.ì> 


ELABORATORE SINGOLO 
GISTI-MA T-?>YA8 

VIDEO 

16 x 64 caratteri 0 
^4 x SO caratteri 0 


0 

0 con _ teriiìin»* 1 i 

MEMORIA 
32 K RAM 
48 K RAM 


0 

0 


CASSETTA 0 


FLOPPY 

?" 

0 

n. cJa_K 

l’uno 

TOT 

_Khytos 

FLOPPY 

8" 

0 

r. da K 

l'uno 

TOT 

_K by tea 

DICCHI 

RIGIDI 

0 

ri. da. f! 

l’uno 

TOT 

_Rhyton 


STAMPANTE MOD. 
STAMPANTE MOD. 
i-LTfTER MOD. 


INTERFACCIA 3IPRINT 0 

MODEM 0 tipo 


HARDWARE NON .STANCARI 
NOTE : 


car/riga 
car/riga 


SOFTWARE DI MAGGIORE .INTERESSE: 



poco 

abbastanza 

n'.olt.o 

gestionale 

0 

0 

0 

SCIENTIFICO 

0 

0 


SOFT. DI BASE 

0 

0 


UTILITÀ' 

0 

0 

0 

educativo e giochi 

0 

0 

0 

ALTRO (specificare): 

0 

0 

0 


NOME E COGNÓME ___ 

INDIRIZZO _ 

CAP E CITTA' ______ 

TELEFONO_/. 


scrìvere a macchina c in atamr.» telilo 
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un byte 

da una tastiera esadecimale 


Ovvero, come usare una tastiera da un nibble per codificare un byte, correggerne a 
piacere i digit. 

Usi: quelli che volete. Io l’ho usata con un EPROM programmer manuale. 


ing. Giuseppe Aldo Prizzi 


Diversi “hobbisti del personal” scrivono dei programmi di utilità 
per uso proprio, che poi conservano caricati in cassetta di na¬ 
stro magnetico. 

Diversi tra essi hanno fatto, per dirla con Marincola, il“grande 
passo”: hanno acquistato o costruito un EPROM programmer. 
lo sono tra loro. 

Dispongo in questo momento di due programmatori per EPROM, uno per 
2516(2 k, monoalimentazione, con impulsi di scrittura di 50 msec, positivi) 
asservito al micro; l’altro a programmazione manuale, costruito -come 
spesso succede- per avere qualcosa di provvisorio per programmare 2758 
e 2532 oltre che le 2516 (2716 Texas). 

Come altrettanto spesso succede, il provvisorio è diventato definitivo, 
lo - in omaggio a una certa velocità di realizzazione- avevo predisposto per 
impostare i dati un bus di otto linee terminali ognuna su un deviatore. 

In questo modo, leggendo i dati dei due nibble (1/ 2 byte) ottenuti suddivi¬ 
dendo le otto linee in due gruppi, e trasformandoli mentalmente da binario 
a esadecimale, mi trovavo nella possibilità di programmare le mie EPROM 
come desiderato, errori di traduzione a parte. 

E basta un errore per dover cancellare e riprogrammare tutta la EPROM. 
Credetemi, il senso di frustrazione che si prova quando alla 2046° cella 
esatta succede la 2047°... sbagliata, è biblico. Uno pensa alle altre sedici- 
mila manovre dei deviatori rese inutili, e cerca lo spigolo più robusto della 
linea Maginot, per sbattervi contro la capoccia. 

Un giorno, non molto tempo fa, ero in quello stato d’animo, e avevo deciso, 
fermamente, di acquistare un EPROM programmer come si deve, costasse 
pure cifre esorbitanti. Il guaio era che cifre esorbitanti venivano chieste 
anche perdei programmatori non più buoni, anzi decisamente meno buoni 
del mio, anche nella sezione che più d’ogni altra induceva le mie crisi. 
Eccomi allora a lavorare di....“testa”, e il risultato lo vedete. 

Ho risolto i miei problemi. 

Se avete EPROM programmer di qualsiasi provenienza, purché funzionan¬ 
ti, e dei quali tutto sommato siete soddisfatti, fuorché, appunto, per il mo¬ 
do di impostare i dati, eccovi un modo di superare le vostre difficoltà: co¬ 
struitevi questo semplice ed economico aggeggio! 
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in byte da una tastiera esadecimale 



Certamente la soluzione che vi propongo potrà sembrare un po’ strana. In 
effetti non è la prima alla quale io sia pervenuto. 

Ma per spiegarvene la genesi dovrò raccontarvi un’altra storia: come tutte 
le storie che racconto, è istruttivaiPermette infatti di vedere come un altro 
reagisce agli stessi problemi che potreste avere voi, e -magari- può sugge¬ 
rire altre applicazioni per la medesima idea, chissà. 

Dunque. Costruita la tastierina che mi serviva -utilizzando un LSI all’uopo 
predisposto, e che quindi non è nemmeno il caso di commentare, almeno 
in questa sede (se ci saranno richieste, lo schema aspetta che valga la pe¬ 
na di essere descritto per dedicargli più spazio sulla rivista - e ne "varrà la 
pena” se le richieste saranno in numero adeguate.... ma, credetemi, non è 
affatto originale), mi trovo il solito amico. 

Non capisco bene: io sono uno degli,esseri più solitari di questo mondo. 
Non ho -o ne ho molto pochi- amici. È incredibile quanti si scoprano miei 
amici, quando hanno bisogno di qualcosa) Ma così va la vita) 

Il solito amico, dicevo. 
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un byte da una tastiera esadecimale 


Aveva comprato una tastierina esadecimale. Anche quella per un prezzo 
spropositato. E volevaicomprarne un’altra, per potere usare una per il nib- 
ble (in questo caso, potremmo dire il “digit”) più a sinistra nella rappresen¬ 
tazione esadecimale dei byte, l’altra per quello più a destra (come dire il di¬ 
git più significativo -Most Significant Digit, MSD; e quello meno significati¬ 
vo -Lower Significant Digit, LSD). 

Così voleva risolvere il problema del “suo” programmatore di EPROM. 
Un sussulto di buon senso lo aveva portato da me, per chiedermi se potevo 
aiutarlo a spendere meno, e a trovare un'altra soluzione meno “stupida” di 
quella che aveva escogitato. 

Eccola. 

Una sola tastierina esadecimale, due quadrupli D-Latches, un mezzo Dual 
J-K FF, un transistorino, due led, qualche immondizia elettronica. 

Il risultato: la pressione del primo tasto carica il MSD del byte, la successi¬ 
va il LSD. Se ho fatto qualche errore, un led verde mi dice che sto carican¬ 
do il MSD, uno rosso che sono sul LSD. Quindi se l’errore è nel digit più si¬ 
gnificativo, ho due possibilità. 

a) mi ci trovo ora (led verde acceso): ribatto il nuovo digit; 

b) sono sul digit meno significativo (led rosso acceso): ribatto lo LSD come 
si trova, e automaticamente mi sposto sul caso a). 

Lo stesso se devo correggere il digit meno significativo (mutatis led): faci¬ 
lino, l’“edit”, vero? 



ywiHr» ’Kittm 
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un byte da una tastiera esadecimale 

Voi capirete che l'impostazione che io ho dato, su due schede, di cui una 
con uno spazio vuoto per accogliere la tastiera, è “su misura” per il caso 
che vi ho descritto, e per tutti quelli analoghi. 

Se invece volete realizzare un’unica scheda, datemi retta mantenete la di¬ 
sposizione separata -sia pure sullo stesso supporto- per sezione tastiera 
(diciamo keyboard? diciamolo pure, ma solo per non perdere l’abitudine a 
usare dei termini che non sono nostri, purtuttavia di uso comune), e per se¬ 
zione “distribuzione dei nibble”. 

lo vi do’ degli Stampati -appunto- separati, collegati tra loro da due connet¬ 
tori a 15 terminali e da un "pettine" di 7 conduttori (i 4 dei dati, i 2 dell’ali¬ 
mentazione, quello dello “strobe”). 

Come funziona 

Distinguiamo: la tastiera e la distribuzione. 

Iniziamo con la prima. Una matrice di 16 tasti (pulsanti) agisce su otto ter¬ 
minali di un integrato CMOS 74C922, costruito apposta come encoder 
(cioè codificatore) binario. 

Traduzione: dette D4, D3, DI le quattro linee di uscita (dati) e ponendo sui 
cappucci dei pulsanti le sedici cifre esadecimali elementari, si realizzerà la 
seguente tabella: 


tasto premuto 

D4 

D3 

D2 

DI 

0 

0 

0 

0 

0 

1 

0 

0 

0 

1 

2 

0 

0 

1 

0 

3 

0 

0 

1 

1 

4 

0 

1 

0 

0 

5 

0 

1 

0 

1 

6 

0 

1 

1 

0 

7 

0 

1 

1 

1 

8 

1 

0 

0 

0 

9 

1 

0 

0 

1 

A 

1 

0 

1 

0 

B 

1 

0 

1 

1 

C 

1 

1 

0 

0 

D 

1 

1 

0 

1 

E 

1 

1 

1 

0 

F 

1 

1 

1 

1 


Come vedete la solita tabella dei primi sedici numeri binari, cominciando 
da zero. 

Segue una parte di un altro circuito integrato: esattamente 5 sezioni di un 
sestuplo buffer (separatore - amplificatore di corrente) non invertente 
74C902. 

Le diverse sezioni amplificano ognuna una linea d’uscita dell’encoderl 
Quattro linee e cinque sezioni? 

Al diavolo la distrazione! avevo dimenticato di dirvi che esiste ancora una 
linea d'uscita: lo strobe. 

Cos’è? beh, semplicemente un impulso che ha lo scopo di “abilitare” un di¬ 
spositivo utente ad accogliere i dati presenti sulle altre quattro linee, 
quelle dei dati. 
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byte da una tastiera esadecimale 








Dice: ma non si vede già che ci sono i dati, che bisogno c’è di un impulso 
che dica che ci sono, benedetti i progettisti, guarda tu che complicazioni ti 
vanno a tirare fuori. 

Dice: inanzitutto lo strobe diventa attivo (nel nostro caso “alto”, così come 
le altre linee) solo dopo che tutti i livelli dei dati sono diventati stabili. Ah, 
già, dimenticavo. Esiste un circuito '‘antirimbalzo" che elimina i falsi con¬ 
tatti -o meglio i loro effetti- quando si premono i tasti. È esso un'integrato¬ 
re, quindi ritarda l'insorgere del segnale d’uscita, che quindi non arriva im¬ 
mediatamente alle linee. In secondo luogo può venire usato -l'impulso di 
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un byte da una tastiera esadecimale 


strabe- come facciamo noi, cioè per comandare un flip-flop che “shifti" al¬ 
ternativamente a destra e a sinistra l’indirizzo del riibble sui due blocchi di 
linee dati! In terzo luogo l’unico limite ad altre possibili utilizzazioni è la fan¬ 
tasia di chi lavora. 



Tastiera: "distributore". 
Diagramma di temporizzazione. 


Ma avete visto, parlando, come si è complicato l'integrato che usiamo? Ba¬ 
sta: ritorniamo a noi. 

Abbiamo visto come funziona -si fa per dire- la tastierina. 

Passiamo al distributore. 

Dunque: dalla tastierina escono le quattro linee di dati e la linea di strabe: il 
tutto in logica positiva. Questo vuol dire che normalmente le cinque linee 
sono a potenziale zero, e che quando vengono portate a 5 V, ad esse è 
associato lo stato logico 1. 

I D-Latch contenuti nei 7475 vengono usati per un temporaneo immagaz¬ 
zinamento dei livelli presenti al loro ingresso. Le informazioni presenti sot¬ 
to tale forma ai terminali di entrata (dati) sono trasferite alle rispettive 
uscite quando il pin Enable (abilitazione) è alto, e le uscite seguono i livelli 
degli ingressi fino a che l’abilitazione rimane alta (a 5 V). 
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immurimi 


un byte da una tastiera esadecimale 



Keyboard: schema elettrico 



Circuito stampato della keyboard, lato rame. 























































































































*. S + - \ l 4 Di h b 

Circuito stampato del “distributore". 

N.B. è visto dal lato rame. Le linee più sottili sono ponticelli (dal lato componenti). 
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un byte da una tastiera esadecimale 



Siccome il 7475 è un quadruplo D-Latch, e siccome l'abilitazione agisce su 
una coppia di tali flip-flop, ecco che ho bisogno di 2 pin di enable, uno per 
coppia: eccoli qui, i pin 4 e 13. 

Appena i pin di enable vanno “bassi” (a tensione zero, livello logico 0), le 
uscite rimangono invariate all’ultimo stato in cui sono state forzate, qua¬ 
lunque variazione abbiano i potenziali d’ingresso. 
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un byte da una tastiera esadecimale 


In questo modo io immagazzino, se i pin 4 e 13 del primo 7475 sono mante¬ 
nuti alti, i dati del digit più significativo fino a che viene il momento di utiliz¬ 
zarli. Ora devo ottenere i dati del digit meno significativo: contestualmente 
all’istante in cui porto azero il livello dell’enable del primo 7475, porto a 1 il 
livello dei pin 4 e 13 del 7475 n. 2. 

Immagazzinare ora i dati di questo digit è un gioco da ragazzi. 

Un led sui pin di enable mi indica quale 7475 sto caricando, quindi se sto 
lavorando sul digit più significativo o su quello meno significativo. 

È abbastanza ovvio che posso agire, per sostituire i dati, o per correggere il 
digit che io avessi sbagliato di impostare, sulla parte di byte che è indicata 
dal led apposito. 

Per ottenere la commutazione automatica del quartetto di D-Latch, uso un 
flip-flop del tipo JK, un 7473 usato come semplice binario forzando a livel¬ 
lo alto i pin di J e K, ed entrando sul terminale di clock. Il 7473 è un doppio 
flip-flop, lo ne uso una sezione solaj 

Per evitare consumi elevati, sarà bene usare integrati del tipo Low 
Schottky (LS), piuttosto che della serie normale, ma non è assolutamente 
tassativo. Dipende da quello che avete in casa) 

Un'ultima cosa: per far si che la commutazione avvenga al termine della 
scrittura utile, cioè prima di scrivere il secondo digit, e siccome dispongo 
di uno strobe in logica positiva, mentre il clock del 7473 è sensibile alle 
transizioni verso l’alto, ho dovuto invertire il segnale di strobe. L’ho fatto 
con un transistore. E ho approfittato di tale fatto per deviare verso l’uscita 
un impulso di strobe di polarità opposta a quello fornito dalla tastierinaa: 
non si sa mai, potrebbe sempre servire, e, visto che c’è.... 

Volendo perfezionare il sistema per ricavare altri nibble su altre linee di da¬ 
ti, in parallelo, contemporaneamente a quelle già ora disponibili, potrete 
sostituire il 7473 con un 4017 contatore ad anello (di Johnson) decadico, 
collegando le uscite progressive ai vari enable di altri 7475 con tutte le en¬ 
trate in parallelo, e le linee di uscita portate ai diversi connettori; l'entrata 
del contatore sarà collegata all'us cita (dello strobe negato), ed userò il ter¬ 
minale CPo, tenendo bassi MR e CRT (collegati a massa). Replicando il ri¬ 
manente dello schema, potrò pilotare fino a dieci 7475. 

Come farete a trovare dieci led di dieci colori diversi, è del tutto affar 
vostro. * $ >» s* «= # # # 9 9 # « * # 9 * « » 9 * « # «< # * # # # * * 
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per la grafica vettoriale 


Modulo pilotabile 

direttamente 

dal 

Data Bus del |jp 

Lear M. Casaroli 


Un problema che abbiamo sia noi hobbisti che i tecnici di Labo¬ 
ratori, Docenti e studenti universitari, ingegneri o ragionieri 
d’Azienda è di disporre di un modulo di qualità per la grafica 
vettoriale, facilmente integrabile nella maggior parte di sistemi 
e/o strumenti di cui già disponiamo. 

La HP ci aiuta a risolvere questo problema annunciando e rendendo dispo¬ 
nibile sul mercato per la strumentazione degli OEM basata su pp, lo HP 
1345A, un compatto schermo completamente autonomo per grafica vet¬ 
toriale ad alta risoluzione. La HP informa, in più, che questo modulo costi¬ 
tuisce il primo membro di una nuova famiglia di moduli display con interfo- 
nia digitale a elevate prestazioni. 

Il nuovo HP 1345A produce grafici vettoriali o alfanumerici (o entrambi 
contemporaneamente) su uno schermo da 6”, in risposta a comandi digi¬ 
tali inviati da un processore esterno. 

Una interfaccia binaria permette la connessione al bus dei dati (Data Bus) 
16 bit TTL dell’Utente. 

Tipici strumenti del Tecnico o dell’Hobbista in cui può essere usato il 
modulo HP 1345A sono ad esempio gli analizzatori di spettro e di reti, gli 
analizzatori di funzioni, gli oscilloscopi con memoria digitale e gli analizza¬ 
tori di Fournier, i tracciatori di curve, o comunque, qualunque apparecchio 
controllato da pp che richieda la rappresentazione di informazioni grafi¬ 
che complesse e variabili con rapidità. 


Grafica ad alta risoluzione 

I 2.048 x 2.048 (4.194.304) punti indirizzabili sullo schermo permettono di 
ottenere una grafica veramente a elevata risoluzione, mentre la qualità 
deN'immagine viene ulteriormente migliorata dalla velocità di scrittura co¬ 
stante che assicura una luminosità uniforme. 

Lo HP 1345A dispone anche, in opzione, di una memoria RAM da4 kvettori 
per effettuare automaticamente il ripristino deN’immagine sullo schermo, 
lasciando la memoria dell’Utente e il pp disponibili per altri usi. 
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Modulo pilotabile direttamente dal Data Bus del pp 



Una ulteriore flessibilità del modulo è data dalla possibilità di programma¬ 
re tre diverse intensità luminose, l’accensione e lo spegnimento, quattro 
tipi di linee e quattro velocità di scrittura. 

La funzione AX programmabile permette inoltre di incrementare automa¬ 
ticamente l’ascissa di una quantità decisa in precedenza dall’Utente, di¬ 
mezzando la necessità di memoria e rendendo più rapida la visualizzazio¬ 
ne. 

I caratteri ASCII sono generati internamente in quattro diverse dimensioni 
programmabili e con quattro diverse direzioni per la didascalizzazione dei 
grafici, l’indicazione di tasti a funzione variabile, e altre applicazioni. 

II tempo medio di scrittura di un carattere è di ~ 15 ps, e permette di visua¬ 
lizzare centinaia di caratteri senza flicker. 
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Modulo pilotabile direttamente dal Data Bus del pp 


Facile integrazione 

Lo HP 1345A è, come detto in epigrafe, facilmente integrabile nella mag¬ 
gior parte di strumenti o sistemi che richiedono un display di elevata quali¬ 
tà. L’integrazione è semplificata dall'interfaccia binaria a 16 bit che facilita 
il collegamento con pp a 8 o a 16 bit, dalla ROM di generazione dei caratteri 
e dal sistema interno di taratura con generazione delle sequenze di check- 
point e con Test Points facilmente individuabili. 

Grazie alla tecnologia adottata per il circuito e al tubo a raggi catrodici a 
deflessione elettrostastica, il consumo totale del modulo alimentato a± 
15Vea + 5V, è inferiore a 25 W, con notevoli vantaggi anche dal punto di 
vista della affidabilità. #«###*«#« 



SYS 310 


RADIOFOTO DA 
SATELLITI METEO 

MAPPE FAX 


PREZZO 

DECODIFICATORE E 
STAMPANTE 

L. 2.480.000 

IVA compresa 


• Decodifica radiofoto da 
Meteosat, Noaa, Meteor 

• Facsimile in onde corte e lunghe 


• Standards: 240, 180, 120, 90, 60 R.P.M.; 267, 576 cooperano 


• Usa carta elettrosensibile, assenza di sviluppo 

• Dimensioni foto 18x18 cm., ottima definizione 


• Montaggio modulare, tecniche PPL, 2 step. - motor 


I1BAB - IW1AM ELETTRONICA FONTANA 

Strada Rìcchiardo, 13 - Cumiana (To) - Telefono (011) 830.100 
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...e per la cultura elettronica in generale ? 
ECCO LA SOLUZIONE ! 

I LIBRI DELL’ELETTRONICA 



L. 5.000 L. 5.000 L. 6.000 



L. 6.000 



1 . 6.000 


DAL TRANSISTOR Al CIRCUITI INTEGRATI: Efficace guida teorico-pratico per conoscere, usare i 
transistor e i circuiti integrati. 

IL MANUALE DELLE ANTENNE: Come conoscere, installare, autocostruirsi e progettare un'antenna. 

ALIMENTATORI E STRUMENTAZIONE: Testo pratico per la realizzazione dei più sofisticati e sem¬ 
plici strumenti di un laboratorio amatoriale. 

TRASMETTITORI E RICETRASMETTITORt: Esempi di come un esperto del settore guida il lettore 
alla costruzione di questi complessi apparecchi 

COME SI DIVENTA CB E RADIOAMATORE: Questo libro ha tutte le carte in regola per diventare 
sia il libro di TESTO STANDARD su cui prepararsi all'esame per la patente di radioama¬ 
tore. sia il MANUALE DI STAZIONE di tanti CB e radioamatori. In esso infatti ogni dilet¬ 
tante. anche se parte da zero, potrà trovare la soluzione a tanti problemi che si incontrano 
dal momento in cui si rimane <• contagiati » dalla passione per la radio in poi. 

COSA E'. COSA SERVE. COME SI USA IL BARACCHINO CB: Il titolo ne è la sintesi. L. 3.500 


Ciascun volume è ordinabile alle edizioni CD. via Boldrini 22, Bologna, inviando l'importo relativo già comprensivo 
di ogni spesa e tassa, a mezzo assegno bancario di conto corrente personale, assegno circolare o vaglia postale. 


SCONTO agli abbonati del 10% 
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Acquisizione dati 
da otto canali analogici 

per 

microcomputer 


Antonio Anseimi 


Il problema che qui si vuole risolvere consiste nel cablare un 
semplice sistema di acquisizione dati analogici, capace di 
fornire a una CPU otto diversi canali, contenenti informazioni 
binarie. 


Prima di addentrarci nel vivo dell'argomento, facciamo alcune semplici 
chiarificazioni a riguardo delle specifiche richieste al sistema. 
Innanzitutto cosa è un sistema di acquisizione dati: questo è uno stru¬ 
mento o circuito elettronico che scandisce automaticamente i dati pro¬ 
dotti da altri strumenti o elabora e registra le letture di tali dati al fine di una 
futura elaborazione. 
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Acquisizione dati da otto canali analogici 


Da tale prima definizione si comprende chiaramente che un tipico sistema 
di acquisizione dati può “lavorare” in due diverse maniere, e cioè on line 
qualora il sistema acquisizione dati/ CPU provveda alla elaborazione dei 
dati istante per istante, ovvero nello stesso istante in cui questi arrivano 
con la conseguente propagazione dalla CPU di segnali di controllo verso lo 
strumento o sensore dal quale i dati medesimi provengono. A tale scopo 
vediamo la figura 1. 

Tipico è il caso in cui una CPU controlla il posizionamento di un pannello 
solare, al fine di mantenere quest’ultimo sempre in posizione ottimale 
(perpendicolare) nei confronti dell’irraggiamento proveniente dal sole, 
mediante la continua elaborazione di dati provenienti da sensori fotoelet¬ 
trici posti sulla superfice del pannello (vedi la figura 2), metodo che va sot¬ 
to il nome di “solar tracking”; oppure il caso simile per l’inseguimento di un 
satellite artificiale, manovrando l’antenna ricevente direttamente dalla 
CPU. 



Un’altra maniera di lavorare è off line, qualora il sistema acquisizione dati/ 
CPU si limiti alla sola memorizzazione dei dati acquisiti per poi elaborarli in 
un secondo tempo (si noti, per i pignoli, che anche la “memorizzazione” 
può essere una forma di elaborazione). 

Il sistema qui descritto, per altro semplicissimo (tre integrati e resistenze 
e condensatori vari), si presta ad ambedue le funzioni indicate, con una li¬ 
mitazione dipendente dal numero di bit disponibili sulle porte I/O della 
CPU in possesso. Tale problema sarà comunque affrontato nel prosieguo, 
e vedremo che sarà aggirabile abbastanza facilmente (leggi: compromes- 
si). 

Torniamo quindi sul discorso dell’acquisizione dati e sulle tematiche ad 
esso annesse e connesse. 

Una volta decisa l’applicazione, on line oppure off line, dovremo stabilire il 
numero di strumenti e/o sensori esterni dai quali, in virtù della applicazio 
ne scelta, ci interessa prelevare quelle informazioni necessarie o alla ela¬ 
borazione o alla memorizzazione: volendo si possono realizzare simulta¬ 
neamente le due funzioni. 

Il sistema qui descritto prevede in input un massimo di otto canali analo¬ 
gici: un numero sufficientemente alto per tutte le applicazioni 
sperimentali-hobbistiche ma che non impedisce anche ai più esigenti di 
sviluppare sofisticatissimi controllers. Ovviamente si possono ampliare ta¬ 
li condizioni ricorrendo a un maggior numero di canali in input: al solito una 
pesante limitazione viene dal numero di bit disponibili sulle porte I/O; 
questo perchè per indirizzare otto canali occorreranno tre bit (2 3 = 8), 
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mentre qualorasi desideri un numero immediatamente maggiore di canali, 
occorreranno più bit per formarei relativi indirizzi (per completezza, occor¬ 
reranno 4 bit per un numero compreso fra 1 e 16, 5 bit fino a 32, etc.). 
Per tale motivo ho scelto un sistema a otto canali, totalmente flessibile in 
quanto ci consente di risparmiare un bit rispetto al sedici canali con la 
conseguente riutilizzazione per altri scopi di un bit. 

Dobbiamo ora risolvere una terza specifica, ovvero quanti bit-dati sono ri¬ 
chiesti per ogni canale. Mi spiego, abbiamo sinora visto che siamo in grado 
di acquisire fino a otto canali, contenente ciascuno una informazione ana¬ 
logica (solitamente una tensione proveniente dal voltmetro o da sensori 
quali fotoresistenze, NTC, etc.): come mi auguro che tutti sappiate, la CPU 
non è in grado di lavorare con tensioni continue ma solo con due valori bi¬ 
nari e quindi è giocoforza operare una conversione da analogico a digitale 
(A/D conversion) su ogni canale che dovrà essere inputtato. E qui viene la 
scelta: è preferibile avere in uscita dal convertitore A/D una stringa di 
quattro bit? oppure 8 o 12? e in quale forma tali dati binari dovranno essere 
presentati alla CPU? in binario puro? in offset o in BCD? Inoltre, quale è il 
range ammissibile della tensione da applicare agli otto canali analogici? è 
una tensione sempre positiva oppure può scendere sotto lo zero? 

A me pare ovvio che lo spazio disponibile non mi permette di illustrare un 
singolo ammenicolo per ogni combinazione delle precedenti, dirò subito, 
quindi, che il sistema in questione presenta le seguenti caratteristiche, in 
rapporto alla discussione cui sopra: 


• numero di canali analogici da acquisire.da 1 a 8 

• numero di bit-dati per canale.8 

• codice di rappresentazione alla CPU.offset binary 

• range della tensione input per canale.da -5 a +5 V. 


Una tale configurazione permette quindi di convertire in binario tensioni 
provenienti dai canali analogici a partire dà—5 V (con stringa binaria corri¬ 
spondente 0000 0000) fino a + 4,96 V (con stringa binaria corrispondente 
1111 1111) con zero centrale (1000 0000). 


canali \ 
analogici 3 


figura 3 



6 bit dati 
offset binary 


Prima di entrare nella considerazione circuitale del sistema, è opportuno 
risolvere una ennesima specifica: ovvero in massimo numero dei canali 
acquisibili per secondo. Questo è un punto fondamentale pertutte le ope¬ 
razioni di acquisizioni dati. I dati possono, ad esempio, essere letti con lun¬ 
ghi intervalli di tempo (anche ore o giorni) mentre possono essere letti alla 
massima velocità consentita dal sistema. 

Facciamo un esempio per ciò che riguarda questo ultimo caso. 

Il nostro sistema ha una velocità di conversione pari a circa 1,8 ms, ovvero 
questo è l’intervallo di tempo richiesto per convertire un valore analogico 
di un canale in una stringa binaria a otto bit, per cui per la completa conver- 
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sione di otto canali occorrerà un tempo approssimativamente uguale a 
14,4 ms (ho scritto approssimativamente in quanto dobbiamo tenere con¬ 
to del tempo necessario al multiplexer per commutare i vari canali): ciò si 
traduce in circa 70 Hz per la conversione di tutti e otto i canali e in circa 556 
Hz per un solo canale. A modificare, in senso negativo, tali tempi interviene 
il tempo necessario alla CPU per la lettura e la memorizzazione. Non credo 
comunque che la maggior parte di noi hobbisti abbia la necessità di acqui¬ 
sire dati che si evolgono a tali velocità: in pratica le esigenze si traducono 
in acquisire dati da semplici sensori con intervalli anche abbastanza lunghi 
(minuti o ore) tramite semplici routine di timer. Ad ogni modo, elenco di se¬ 
guito le caratteristiche della parte riguardante la conversione A/D: 


• risoluzione .... 

• tempo di conversione 

• non-linearità . . . 

• drift di temperatura . 


8 bit in offset binary 
1,8 msec (massimo) 
±1/2 LSB (massimo) 
± 50pV/ °C (massimo) 


Iniziamo la discussione circuitale, elencando le linee di collegamento fra 
microcomputer e sistema di acquisizione dati: 

linee di input 

2 di controllo provenienti dal convertitore A/D 
8 provenienti dal convertitore A/D costituenti il dato binario offset 


linee di output 

3 necessarie per indirizzare gli otto canali (massimo) 
2 necessarie al controllo del convertitore A/D 
1 necessaria al controllo del multiplexer 


Fanno in totale 16 bit che dovremo collegare al microcomputer. 

addre ss 


figura 4 


dolo input 



sA en ini 

“i mimi 



tir 

1 1 I£1 *1 1 1 1 1 IMI 

TTTTT’s 


porro i/o 


Personalmente, disponendo di una CPU a 16 bit, ho adottato la configura¬ 
zione di figura 4, ovvero: • porta di sedici bit usata per l'input delle stringhe 
binarie (8 bit) • controllo multiplexer (1 bit) + address (3 bit) •controllo 
convertitore (2 bit) • registro programmabile interruzioni usato per il 
controllo fine conversione (1 bit); mi rimangono quindi due bit liberi della 
porta per pilotare un digitai power che azionerà due motorini. Ovviamente, 
si guadagna un bit come detto in precedenza, riducendo il numero dei ca¬ 
nali analogici da acquisire. 

Per ciò che riguarda le linee di controllo queste sono: 
start conversion: impulso di inizio conversione che deve essere manda¬ 
to al convertitore A/D. Tale impulso può essere man¬ 
dato dalla CPU per intervalli di tempo prestabiliti op¬ 
pure può essere fornito da un clock a parte (rispar¬ 
miando in tale modo un altro bit sulla porta I/O) o un 
registro di timer interno al microcomputer, 
data valid: proveniente dal convertitore A/D e che servirà per lan¬ 

ciare una richiesta di interruzione alla CPU. Tale linea 
indica, come vedremo dal diagramma temporale, che 
alle uscite del convertitore A/D sono presenti i validi 
valori binari della tensione presente al suo ingresso. 
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enable: necessaria per abilitare le uscite (3-state) del 

convertitore. 

inhibit: necessaria per abilitare il funzionamento del 

multiplexer. 

Le altre linee sono: 

data input: otto linee contenenti il codice binario offset, 

address: tre linee atte a formare l’indirizzo del canale che si 

vuole selezionare. 

Ciò detto, veniamo all’analisi del semplice schema (vedi figura 5 e 6) del si¬ 
stema presentato. 


CD4051B, CD4052B, CD4053B Types 


MAXIMUM RATINGS, Absolute-Maxtmum Values: 

OC SUPPLV VOLTAGE RANGE. (V 0D ) 

^0IU|.S IO v ss o. V EE . «.iociwxi >1 inoli n«((t..i). -0.5 IO »20 V 

INPUT VOLTAGE RANGE. ALL INPUTS.-0.5 io Vqq «0.5 V 

DC INPUT CURRENT; ANV ONE INPUT.•. HO mA 

POWER DISSlPATlON PER PACKAGE (Po>: 

Por T a - 40 io «60°C (PACKAGE TYPE E). 600 mW 

Por T A ^ ‘60 io »85 0 C (PACKAGE TYPE 61.Dciatc Linecrly »t 12 mW/°C lo 200 mW 

fo. I A • -5510 •)00°C (PACKAGE TYPES O.F) .■ 500 mW 

FOf T A <100 io «126°C (PACKAGE TYPES D,F) . Derata Linwriy «t 12 mW/°C to 200 mW 

DE VICE DISSlPATlON PER OUTPUT TRANSISTOR 

POR T A « FULL PACKAGE TEMPERATURE RANGE (All PacltaaaTvpeO. 100 mW 

OPERA TINO-TEMPERATURE RANGE (Ta): 

PACKAGE TYPES D. F. H . -65lO«12S°C 

PACKAGE TYPE E . _*o ,o «66°C 

STORAGE TEMPERATURE RANGE (T f|( ,|. _ft6 io «160°C 

LEAD TEMPERATURE IDURING SOLOERING): 

Ai dittane* 1/16 * 1/32 ioch (1.59 i 0.J8 mml hom caia for 10 f ma». *2C6°C 







INPVT SlQMAL VOLTACI IV,,» — V 


figura 5 



figura 6 


Il multiplexer usato è un COSI MOS siglato 4051B, il quale multiplexa se¬ 
gnali analogici. Niente di particolarmente strano a proposito di tale inte¬ 
grato, se non il fatto del piedino di inhibit (active High) che abilita il multi¬ 
plexer al funzionamento e la possibilità di programmare dall’esterno il ran- 
ge della tensione analogica agli otto ingressi. Infatti il segnale analogico 
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Acquisizione dati da otto canali analogici 

attraverso iTG, vedi figura 5, può variare fra VEEfino a Vdd: quindi per otte¬ 
nere la variazione ±5 V necessaria ai nostri scopi, dovremo operare i se¬ 
guenti collegamenti: 

Vdd collegato al +5 V; 

Vee collegato al -5 V; 

Vss collegato allo zero centrale, massa del sistema. 

Il canale selezionato con la cifra binaria agli ingressi A B e C del 4051 (pie¬ 
dini 11,10 e 9) apparirà all’uscita (piedino 3) qualora il comando di inhibit 
sia disattivato (uno zero logico al piedino 6). 

E enfatico dire che il cuore del sistema è costituito dall'integrato ET8BC 
^prodotto dalla Datel Intersil), la quale configurazione è visibile nelle figure 

Prima di descriverne il funzionamento, guardiamo insieme alcune 
caratteristiche. 


MECHANICAl DIMENSIONS 
INCHES (MM) 


CERAMIC 

PACKAGE 


PLASTIC 

PACKAGE 


34 (3811 „ 

■nnnnnrinnnnrtn 


DATEL 

BFlNTEHtM. 

ADC-ET12BR 



T 

uo 

l'S 81 

i. 


r 
L 
<00 <1 




^ i-,: 



. figura 7 


La prima cosa che salta all’occhio è la possibilità dell’integrato di fornire in 
uscita un numero variabile di bit: da 8,10 e 12 bit. Come detto in preceden¬ 
za, noi usiamo tale integrato peravere in uscita stringhe da 8 bit, quindi do¬ 
vremo collegare le linee data input con i seguenti piedino dell’ET8BC: il 
piedino 12 rappresenta sempre il bit meno significativo, e quindi a tale pie¬ 
dino andrà collegata la linea meno significativa del data out. 
Proseguiremo poi nei collegamenti, fino ad arrivare al piedino 5 che rap¬ 
presenta il bit più significativo, nel caso di uscita a 8 bit. Ad ogni modo, ciò 
è esaurientemente illustrato nella figura 9. 

Le uscite digitali dell’ET8BC possono pilotare due carichi del tipo Low 
PowerTTL oppure un carico Low Power SchottkyTTL, quindi sono compa¬ 
tibili con la tecnologia CI MOS. Quando l’input start convert è attivato da 
un impulso (largo almeno 500 nsl), la uscita busy va alta e inizia un ciclo, di 
circa 10 ps, durante il quale viene scaricata la capacità di integrazione 
nonché resettati i due contatori contenuti aH'interno dell’ET8BC. La con¬ 
versione vera e propria inizia dopo un impulso di reset interno. La fine con¬ 
versione è segnalata da un impulso generato dal clock counter (sempre in- 


- XÉLECTRON 3/82- 


-65- 























Acquisizione dati da otto canali analogici 


terno all’integrato) oppure generato dal clock counter nel caso, spiacevo¬ 
le, di un overflow; tale impulso disabilita ulteriori ingressi verso i contatori 
e inizia un ciclo shutdown, della durata di circa 10 ps (a tale proposito si 
cerchi di consultare parallelamente il mio scritto, con il diagramma tempo¬ 
rale di figura 10). 




figura 9 
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5 tartconvert — 
busy — 


-SOOnstmin ) 


- 300ns 


reset 


Kp s 


10 /j s 


shutdown 


1 

0 

1 

0 


figura 10 


data valid 


1 

~* 5ps 0 

data out a Y 

B 


-^—SOOns 


A = dati relativi alla conversione iniziata all'impulso n—1. 
B = dati relativi alla conversione iniziata all’Impulso n. 


All’interno dello shutdown, l’uscita data valid va bassa (segnale che usere¬ 
mo per lanciare l’interrupt) per circa 5 gs, al termine dei quali torna bassa 
l'uscita busy e sulle uscite digitali è presente il codice binario offset della 
conversione effettuata. A questo punto, dovremo inviare il segnale di ena- 
ble all’ET8BC al fine di sbloccare le uscite e prelevare così l’informazione 
binaria. 

Lo schema completo è visibile a figura 11 : si noti la presenza dell’amplifi- 
catore operazionale 776 il quale serve a dare la corrente di offset dalla ten¬ 
sione di riferimento. 
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Guardiamo attentamente lo schema, e cerchiamo di capire i vari valori as¬ 
segnati ai componenti passivi. 

Al piedino 17 dell’integrato (piedino di bias) va collegata una resistenza di 
polarizzazione del valore di 100 kQ, con tolleranza massima del 10%, un 
terminale di tale resistenza va collegato al negativo della alimentazione 
(-5 V); i piedini 18e 19 vanno collegati, come vedesi in figura9, rispettiva¬ 
mente al —5 e +5 V per la alimentazione. È consigliabile bypassare verso 
massa entrambi tali piedini, tramite due condensatori di valore 100 nF. 
La tensione negativa di riferimento deve essere applicata al piedino 13, ed 
è ottenuta tramite uno zener e una resistenza da 3.600 G collegata al -5 V 
della alimentazione. La resistenza in serie all'ingresso della tensione di ri¬ 
ferimento deve essere tale da far scorrere una corrente di 20 pA: usando la 
formula di Ohm avremo 

R = V r if/ 20 pA 

ovvero, usando una tensione di riferimento di -1,22 V 

R = 61 kQ 

la quale dovrà essere del tipo a film metallico, per ovviare agli inconvenien¬ 
ti degli sbalzi di temperatura. Logicamente, la precisione della conversio¬ 
ne dipenderà in massima parte dalla precisione della tensione di riferi¬ 
mento, per cui si preferisce avere una regolazione del 4 % su tale tensione. 
La resistenza in serie all'ingresso analogico è calcolabile dalla 
R = FSR/ 10 pA 

dove FSR è la variazione picco-picco della tensione in ingresso. 

Il nostro sistema prevede una escursione da —5 a +5 V, per un valore 
picco-picco pari a 10 V; il valore di tale resistenza sarà quindi 

R = 1 MG 

Ad ogni caso, in serie a tale resistenza metteremo un trimmer multiglri, re¬ 
golato in fase di taratura, del valore di circa 1 °/o di 1 MG, ovvero da 10 kQ: 
tale trimmer ci servirà per la regolazione del guadagno. 

Sull’uscita dell’amplificatore operazionale troviamo una serie di un trim¬ 
mer (anch’esso multigiri) con una resistenza: tale servirà all’aggiustamen¬ 
to della corrente di offset. Gli altri condensatori sono ceramici. 

Ad ogni modo questa è la lista dei componenti: 

fi, 3.600 Q 
fi, 20 kQ 
fi 3 20 kQ 
fi„ 61 kO 

R 5 2,2 kQ, trimmer multigiri 
Re 244 kQ 
Rj 6,2 MQ 

R g 10 kQ, trimmer multigiri 
Rg 1 MQ 
Rio 100 Q 
Rii 100 kQ 

Ci 270 pF ) 

C 2 6S pF (capacità di integrazione) ' tutti ceramici 
C 3 100nF l 

C 4 100 nF I 

zener LM 113 

In figura 12 riporto la tabella della verità per decodificare gli address per gli 
otto canali analogici in ingresso al 4051. 
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input States 

canale “ON” 

inhibit 

C B A 

0 

0 0 0 

0 

0 

0 0 1 

1 

0 

0 1 0 

2 

0 

0 1 1 

3 

0 

1 0 0 

4 

0 

1 0 1 

5 

0 

1 1 0 

6 

0 

1 1 1 

7 

1 

XXX 

nessuno 


A questo punto non mi sembraci sia nulla da aggiugere a quanto detto, ri¬ 
porto solo nelle figure 13 e 14 le curve caratteristiche dell’integrato 
ET8BC. 

Per ciò che riguarda il diagramma di flusso del software annesso al sistema 
di acquisizione dati, mi sembra che sia abbastanza estraibile: occorre solo 
molta attenzione ne! conteggio dei tempi, quindi occorre fare bene i conti 
con il clock della CPU che voi usate e fare in modo da starci “larghi” (a tale 
proposito, ricordo inoltre di tenere bene in co nto i rita rdi di propagazione 
per l’ingresso inhibit del 4051 e dell’ingresso enable dell’ ET8BC). 

Ad ogni modo una tipica sequenza potrebbe essere questa: 

- inizìalizzazione delle porte I/O; 

- inizializzazione registri e puntatori; 

- disabilitazione dell'interrupt; 

- disabilitazione al 4051 (1 logico al piedino 6); 

- A) formazione dell'indirizzo del canale scelto; 

- B) out dell’indirizzo verso il 4051; 

- abilitazione al 4051 ; 

- start conversione verso ET8BC; 

- abilitazione dell'interrupt; 

- accettazione dell'interrupt; 

- abilitazione all'uscita digitale dell’ET8BC (zero logico al piedino 24); 

- disabilitazione al 4051; 

- acquisizione in memoria del dato letto sulla porta input; 

- disabilitazione dell’interrupt. 

A questo punto la CPU entra in un loop di ritardo che può essere vantag¬ 
giosamente utilizzato o sistemando i dati letti in memoria e incrementan¬ 
do il relativo puntatore o elaborando i dati finora letti; quando la CPU rien¬ 
tra dal loop di ritardo si procederà per due strade diverse, a seconda che si 
vogliano dati da un solo canale o da n canali: 

tornare al punto A incremento dell’indirizzo 
tornare al punto B 

procedendo naturalmente a una verifica, che consenta alla CPU di sapere 
esattamente su quale canale agisce il multiplexer (ad esempio, se è il caso 
di tornare sul primo canale scelto in quanto sono già stati “esplorati” tutti i 
canali scelti per l’acquisizione). 
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TYPICAL PERFORMANCE CUHVES 


OUTPUT SOURCE CURRENT 
vs TEMPERATURE 



IOH(mA> 


OUTPUT SOURCE CURRENT 



.1 1 10 
lOH(mA) 


OUTPUT SINK CURRENT 
vs TEMPERATURE 



OUTPUT SINK CURRENT 
va SUPPLY VOLTAGE 



LINEARITY va | REF 



IrEF^A) 


THREE-STATE PROPAGATION 


DELAY 


NORMALIZEO PROP. 
DELAY 

b ó» « o M b 
































Vss --5V 
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TEMPERATURE <*C) 


figura 13 
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CONVERSION TIME 



10K 100 K 1M 

R BIAS< 0HMS > 


CONVERSION TIME 
Vi TEMPERATURE 



TEMPERATURE < 4 C) 


CONVERSION TIME 
va. SUPPLY VOLTAGE 



< 

£ 

v> 


a 

Q 


SUPPLY CURRENT 



2 3 4 5 6 7 8 

VDD= Vss(VOLTS) 


SUPPLY CURRENT 



10K 100K 1M 

r b,as< ohms ) 


SUPPLY CURRENT 



- 55-25 0 25 50 75 100 125 


TEMPERATURECC) 


figura 14 


Naturalmente ciascuno potrà giocare quanto vuole con le istruzioni possi¬ 
bili, fissare a un livello (0 o 1) uno degli indirizzi o addirittura tutti e tre gli in¬ 
dirizzi, nel caso in cui si voglia acquisire dati da un solo canale; in tale modo 
si risparmieranno tre bit e un bel po’ di istruzioni. 

Non aggiungo altro se non un buon lavoro e buon divertimento. * * * 
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come una intuizione può trasformarsi in un incubo 


La prova del nove 


ing. Luca Crispa 

una macchinetta che vi dice se i vostri calcoli sono esatti 


Era cominciato tutto come un gioco. 

Le vacanze estive stavano perterminare, e ci si trovava t, ulti im¬ 
mersi nel mondo della scuola, chi coinvoltovi direttamente 
—come i figli, e il sottoscritto— chi indirettamente, ma non meno 
intensamente, come la —rispettivamente— moglie e madre. 
Riincomincia la scuola, dunque, e con essi i relativi problemi. 
Compresi quelli di aritmetica. 

Che toccava a me, come padre e “testa d'uovo” della famiglia, 
sbrogliare. 

La soluzione che la tecnologia ci mette davanti: l’eterna macchinetta cal¬ 
colatrice elettronica, non soddisfaceva il mio istinto di educatore. 
Avrebbe soddisfatto, ben s'intende, quelle di scansafatiche delle figlie. La 
maggiore delle quali, al mio ennesimo rifiuto di permetterle l’uso della Tl- 
58, con l'aria di darmi l’ultima mazzata, dimostrando la sua ragionevolezza 
contrapposta alle mie dittattoriali pretese, si diede invece la classica zap¬ 
pa sui piedi. 

“Non è che io non sappia impostare le soluzioni, nè risolvere i problemi — 
cinguettò la sciagurata- che il profe mi assegna. Nè (che Dio ci guardi) mi 
spaventano le operazioni pur nella loro immane complessità. 

Quello che mi sgomenta —continuò angelica— è il non sapere se il risultato 
delle varie operazioni è esatto. Ora, se tu mi facessi una trappoletta, un ag- 
geggetto, una specie di “prova del nove” elettronico, che mi eliminasse la 
necessità di perderci tempo, io non avrei bisogno della calcolatrice (ed era 
certa che fosse impossibile, aveva già girato tutte le rivendite di materiale 
elettronico della zona) che, credimi, non mi serve ad altro che a controllare 
il risultato del mio lavoro. 

Se invece, non puoi farlo —e lanciò l’ultimo perfido siluro, unendo in un solo 
mazzo la mia incompetenza e l’alta autorità materna—, anche la mamma è 
d’accordo che io possa usare la tua macchinetta (la TI-58, capite gente, 
stampante inclusa ...)”. 

Notti insonni. 

E riprendi a sfogliare i tuoi libri. 

Mentre lei, la figlia, radiosa, ti interdice l’uso della TI-58 e ti esaurisce le 
scorte di carta termica. 
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Evviva la National! 

Il grido che lanciavo quel giorno riecheggiava ancora per la casa, e mia fi¬ 
glia -tutta ingrugnata— si è vista riespropriata della calcolatrice di suo pa¬ 
dre e, dal giorno di Natale, lavora con l’aggeggino che vi presento e che ho 
ribattezzato, in ricordo dell'ukase, “prova del nove”. 

Il tasto magico 

Il mio -si fa per dire, ché di mio c’è solo il circuito stampato— progettino si 
sviluppa attorno al circuito integrato MOS-LSI MM5780 della National. 



È questo un componente che utilizza un processo di produzione a gate 
metallico (è questo il significato della M di MOS), canale P (ovviamente di 
silicio, il semiconduttore che dà la S alla parola MOS, mentre la O rappre¬ 
senta lo strato di biossido di silicio tra M e S), e tecnologia che combina i 
due modi ‘‘svuotamento e riempimento” ovvero “enhancement e 
depletion”. 

L'obiettivo principale della sua produzione è stato uno sviluppo a basso 
costo per permettergli di assolvere il compito di “giocattolo educativo", 
anche esso a basso costo. 

Infatti, oltre al circuito integrale stesso, l’intero set richiede 18 tastini, un 
interruttore, uno zoccolo a 24 pin, un circuito stampato, due led a colori di¬ 
versi, un connettore per pila, e una pila a 9 V. 

Tutto il rimanente del circuito, compreso l’encoder da tastiera, i circuiti an¬ 
tirimbalzo, la generazione di impulsi di clock e la temporizzazione, i buffer 
verso i led, sono tutti “on-chip”, cioè inclusi nel componente e non richie¬ 
dono alcun componente esterno. 

I problemi vengono fatti entrare nella macchina in forma algebrica, esatta¬ 
mente come essi vengono scritti dall’allievo nelle sue Indicazioni, sulla pa¬ 
gina del quaderno. 

Lo studente provvede la risposta e il fattore mancante e, al termine di tale 
operazione, preme il tasto ‘‘TEST”. Si accenderà un led verde se la risposta 
e il dato inseriti erano esatti, altrimenti il led che si accenderà sarà rosso. Si 
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può ritentare la soluzione del problema, e—cosa da non trascurare e che la 
rende adatto per allievi di scuole anche di grado superiore 
all’elementare—si possono trattare anche numeri negativi. Ma questo ri¬ 
sulta più chiaro degli altri esempi a corredo, in calce all'articolo. 






Layout del circuito stampalo, in grandezza vera, per ambedue le facce. 
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Avrete già capito che il bello di questa macchina è che 
essa NON fornisce il risultato di nessuna operazione, ma 
si limita a segnalare se quello ottenuto è esatto: quindi 
nemmeno il professore di matematica più intransigente 
può obiettare nulla al suo uso. 

La vita della batteria è stimata da 10 a 30 ore di lavoro effettivo, quindi lun¬ 
ghissima, a seconda del suo stato. 

Nel chip esiste anche un circuito comparatore di tensione: il suo scopo? 
Quando la tensione della batteria scende sotto il livello operativo, esso di¬ 
sabilita ambedue gli indicatori a led: nessuno di essi sì accenderà premen¬ 
do il tasto “TEST". 
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Un led inserito con il suo resistore adeguato tra il pin 1 e quello 12 indica se 
il chip è “ready”, ovvero se sta svolgendo un’operazione: a me non impor¬ 
tava, quindi non l’ho inserito. 

Esistono altre prestazioni valide dal punto di vista tecnico, ma per lo stes¬ 
so motivo non ne tratto, invitando gli interessati a leggersi il manuale 
MOS/1980 della National, reperibile presso tutti i fornitori di letteratura 
tecnica. 


Le righe che precedono, unitamente allo schema elettrico e al layout del cir¬ 
cuito stampato potrebbero già bastare per una buona parte dei miei lettori, 
ma per quelli che desiderano uno sguardo maggiormente approfondito, ec¬ 
co qui alcuni altri: 


appunti tecnici 

Come era già evidente dal fatto che si utilizza uno zoccolo dual-in-line da 
24 pin, anche il nostro circuito integrato presenta lo stesso numero di piedi¬ 
ni. Le loro funzioni sono: 


1 Ready 

2 Digit 9 

3 Digit 1 

4 Digit 2 

5 Digit 3 

6 Vdd (-alim.) 

7 NC 
8NC 


9 N C (non connesso) 

10 NC 

11 NC 

12 l/ ss (+ alim.) 

13 NC 

14 NC 

15 “Right” indicator 

16 ‘‘Wrong’’ indicator 


17 Key input 1 (K 1) 

18 K 2 

19 K 3 

20 Digit 8 

21 Digit 7 

22 Digit 6 

23 Digit 5 

24 Digit 4 


N.B. Ready è un flag (indicatore) che non è connesso al circuito esterno, ma 
che cambia stato a seconda se il chip sta o no lavorando (vedi anche il testo 
precedente). 

Digit è una parola inglese che significa “cifra". 

Right e Wrong significano “esatto"e “errato”e sono ipiedini a cui viene con¬ 
nesso il led relativo: anch'essi quindi sono dei "flag", soltanto che vengono 
usati anche come indicatori visivi dell'esattezza della risposta. 

Key input sono i tre terminali che rappresentano le connessioni comuni per 
le tre file di tasti, numerici e di funzione. 


tabella 1 


Descrizione del segnale “ready" 

Funzione del chip Segnale ready 


In riposo 


Il flag ready sta a riposo, al potenziale logico High (Vss) 


Tasti premuti e 
svolgimento operazioni 

Tasti rilasciati e ritorno 
allo stato di riposo 


Quando viene premuto un tasto, viene dato il via alla temporizzazione che 
assicura stabilità sugli eventuali rimbalzi. Ready rimane High fino a che tale 
tempo è terminato, e il tasto è premuto: ritorna poi Low (Vdd). 

Ready rimane Low (basso) fino a che il tasto rilasciato ha terminato il rim¬ 
balzo e il chip è tornato allo stato di riposo. La transizione da basso ad alto 
segnala il ritorno allo stato di riposo, in cui il livello logico rimane alto. 


La tabella sopra riportata dà un'idea molto chiara di cosa succede ed è rile¬ 
vabile oscillograficamente al pin 1. 

Quella invece che segue indica come cambiano gli stati logici aipin15e16 
-rilevabili con i led indicatori-, e come interpretare quindi la luminosità di 
tali led. 
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tabella 2 


Tavola della verità degli indicatori 


Condizioni del chip 

Uscita degli indicatori 

pin 15 

pin 16 

L'ultimo tasto premuto è stato quello di "TEST", ed è stata data una 
risposta corretta. 

High 

Low 

L ultimo tasto premuto è ancora quello “TEST", ma la risposta forni¬ 
ta è sbagliata, oppure il problema è scorrettamente impostato, o 
ancora esiste una condizione di “overflow"(superamento della ca¬ 
pacità numerica del chip). 

Low 

High 

L'ultimo tasto premuto è diverso da quello "TEST", ma non si verifi¬ 
cano altre condizioni di errore. 

Lo w 

Low 

L'ultimo tasto premuto é “CLEAR" (cancellazione). 

Low 

Low 

La tensione di batteria è scesa sotto il valore di funzionamento del 
5780. Si verifica premendo il tasto “TEST". Se non si accende alcun 
led, la batteria deve essere sostituita. 

Low 

Low 



N.B. gli errori, o l'impostazione scorretta a cui si fa cenno di sopra, sono esclusivamente di tipo matemati¬ 
co (il chip non è in grado di dirvi se la formula che state usando è esatta o noi), come ad esempio una divi¬ 
sione per 0 (zero)! 


Passiamo ora alle: 


operazioni con i tasti ed esempi di problemi 


Tasto “CLEAR": 
Entrata dei numeri: 


Punto decimale: 


+ 


- X -5- 


cancella tutti i registri e riporta la macchinetta allo 
stato preferito: quello di riposo, 
il primo entrato pulisce il registro di ingresso e fa “en¬ 
trare" il numero nei registro della cifra meno significa¬ 
tiva (LSD = Least Significant Digit), spegnendo con¬ 
temporaneamente l'eventuale led acceso. 

I prossimi numeri fino all'ottavo “shiftano” (spostano) 
quelli precedenti uno alla volta, sospingendoli nel re¬ 
gistro adiacente, fino a quello MSD (cifra più signifi¬ 
cativa, Most Significant Digit). Il nono e seguenti ven¬ 
gono semplicemente ignorati, e non causano condi¬ 
zioni di errore. Se esiste un punto decimale, I digit ac¬ 
cettati sono solo 7, e gli altri vengono ignorati, con le 
stesse condizioni. 

per noi corrisponde a “virgola decimale”. Viene pre¬ 
muta per inserire tale segno nella cifra che si sta im¬ 
postando. 

(somma, sottrazione, moltiplicazione, divisione). 
Premendo uno di tati tasti dopo aver inserito un nu¬ 
mero, si obbliga l'entrata a riconoscere i numeri suc¬ 
cessivi come parte del secondo; predispone il calco¬ 
latore ad effettuare l’operazione indicata, e registra la 
funzione premuta come la prossima operazione da 
effettuare dopo aver fatto entrare il numero seguente. 
Pressioni successive di diversi tasti di funzione, sen¬ 
za che vengano inseriti numeri, o punto decimale, 
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cancellano le pressioni precedenti (cioè, se io pre¬ 
mo, ad esempio, + — + x l’operazione che verrà svol¬ 
ta, se io tra i segni di operazione non ho inserito nu¬ 
meri, sarà quella di moltiplicazione, 

= (eguale): la prima pressione dopo aver fatto entrare un numero 

provoca il riconoscimento del termine di tale numero 
da parte del chip, e fa effettuare la operazione prece¬ 
dentemente registrata, provoca la registrazione della 
pressione del tasto Se tale pressione avviene do¬ 
po un segno di operazione, senza interpolazione di 
numeri, essa viene semplicemente ignorata, a meno 
che il segno di operazione non sia “x", cioè un prodot¬ 
to. In tal caso il chip effettua un’elevazione al quadrato. 

Entrata dei risultati: i risultati vengono fatti entrare semplicemente immet¬ 
tendoli premendo i tasti “digit” dopo i’“eguale”, e 
“battendo" il numero che si prevede sia il risultato. 
Esso viene inteso come positivo (e NON SI DEVE bat¬ 
tere il “+”prima di esso), mentre SI DEVE battere il 
prima dì esso se si prevede un risultato negativo. 

TEST: il tasto T viene usato per terminare il calcolo e per ef¬ 

fettuare il confronto tra il risultato fornito dallo stu¬ 
dente e quello che il calcolatore ha effettuato e im¬ 
magazzinato. Se essi coincidono si accende il led 
verde, altrimenti quello rosso. In tale ultimo caso 
NON È SUFFICIENTE battere un altro “risultato", ma 
bisogna reimpostare l’intera operazione. 


Infine, come risulta da quanto detto, il nostro aiutante è in grado di effettuare 
operazioni “in serie”, cioè nell’ordine in cui vengono battute, senza ricono¬ 
scere alcuna gerarchia, nè poter usare le parentesi per imporla: attenzione, 
quindi! 

Esempio di somma: 

voglio effettuare l'operazione 7 + 18 = .... e verificare il mio risultato 


tasto premuto 

led acceso 

commenti 

C 



C 

nessuno 

il doppio "CLEAR" è necessario 
all'accensione dell'apparecchio 

7 

nessuno 


+ 

nessuno 


1 

nessuno 


8 

nessuno 


= 

nessuno 


2 

nessuno 


5 

nessuno 


TEST 

verde 

risposta esatta 

Se invece, dopo l'eguale, io avessi avuto 


2 

nessuno 


4 

nessuno 


TEST 

rosso 

risposta errata 
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Per poter effettuare la verifica, avrei dovuto ripetere tutta la routine già effet¬ 
tuata, iniziando dalla prima riga (però se non l’ho spento, basterà un solo 
C..., o addirittura nessuno, visto che il TEST ha già effettuato un CLEAR) e for¬ 
nendo una nuova risposta. 


Altro esempio: trovare y in 9 + y = 17 


fasto premuto 

led acceso 


9 

nessuno 

l'eventuale indicatore acceso di spegne. 

+ 

nessuno 


8 

nessuno 

introduco la mia ipotesi per y 

= 

nessuno 


1 

nessuno 


7 ■ 

nessuno 

termina la mia risposta 

TEST 

verde 

OK 
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Ancora un esempio: 8 2 = 


8 


x 


6 

4 


nessuno 

nessuno 

nessuno 


l’eventuale indicatore si spegna 

il complesso x - effettua l'elevamento 
alla seconda potenza 


TEST 


nessuno 

nessuno 

verde 


termino la risposta 
OK 
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L’ultimo: 


7 

nessuno 

l’eventuale led acceso si spegne 


nessuno 


a 

nessuno 


+ 

nessuno 


i 

nessuno 


X 

nessuno 


3 

nessuno 


-*■ 

nessuno 


1 

nessuno 


2 

nessuno 


= 

nessuno 


4 

nessuno 

Introduco la risposta 

TEST 

verde 

OK: ho effettuato (7+8+1)x3 = 4 



12 


Infine: cercavo l’altro giorno la TI 58. 

L'aveva mia figlia: si stava stampando I “bioritmi”: vuoi vedere che dovrò 
cercare un integrato LSI che li calcoli? 

Incubo! Ma per fortuna c’è la National! 


RADIOSURPLUS - IERI E OGGI 

• 288 pagine 

• oltre 60 fotografie di apparati 

• oltre 80 schemi elettrici e circuiti 

• tabelle, grafici, dati tecnici 

• stampato su carta lucida ed elegantemente confezionato 

È la prima opera in Italia dedicata al surplus civile e militare, 
italiano e straniero, veramente completa, indispensabile 
per i Collezionisti, per consultazione, e come spunto e gui¬ 
da per modifiche, ripristino, utilizzo pratico per OM-CB- 
SWL. 


SCONTO 10% per gli ABBONATI 
SPESE DI SPEDIZIONE A NOSTRO CARICO 

Suggeriamo di effettuare i pagamenti usando per comodità assegni, pro¬ 
pri o circolar); in seconda battuta i vaglia, e come ultima soluzione i versa¬ 
menti in conto corrente, intestati a «edizioni CD» n. 343400. 


6° volume della collana 
I LIBRI DELL’ELETTRONICA 
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COMMUNICATIONS COMPUTER 
TONO 9000 E 

Tono 0 - 9000 E sistema per comunicare in CW/F1 (Murray/Ascii) 
governato mediante pP. 



Versione radicalmente nuova dell’ormai nota © 7000 E 
con flessibilità operative ancora più estese. 

Questo modello infatti conserva le fondamentali 
possibilità operative precedenti: CW - RTTY, estendendo 
nel contempo l’apparato all’uso di video grafici nonché 
alla redazione di testi. 

E possibile perciò scrivere ad esempio una lettera, quindi 
mantenendola in memoria, apportarvi tutte le correzioni 
successive del caso, ed Infine effettuare la stampa del 
testo corretto in modo impeccabile mediante l’annessa 
stampante opzionale HC-900. La memoria è capace di 
14.000 caratteri, mentre ciascuna “pagina” visualizzata 
contiene 24 linee dì 80 caratteri ciascuna. Mediante 
l’apposita sonda (o penna luminosa) è possibile tracciare 
sullo schermo grafici o disegni che potranno essere quindi 
trasmessi senza dover procedere al tradizionale sistema 
dattilografico adottato sinora per la trasmissione di 
disegnini marginalmente abbozzati. 

La memoria elastica dispone di 3120 caratteri, per cui si 
potrà preparare la risposta per il corrispondente - 
mediante la possibilità offerta dallo schermo dimezzato - 
nel leggere il messaggio in arrivo, quindi procèdere 
all’emissione con la massima velocità consentita. 




Tutte le 
funzioni 
indispensabili 
al traffico RTTY 
sono state 
automatizzate, 
perciò i sani principi operativi 

acquisiti con le versioni meccaniche (ad es. Carr. Ret. - 
Line Feed, ecc.) sono divenute ormai una 
programmazione normalizzata. Lo speciale demodulatore 
CW si adatta bene a diverse velocità di manipolazione, 
mentre, durante la trasmissione oltre che alla velocità, è 
possibile modificare pure la “pesatura”. Le funzioni RTTY 
includono le lettere e frasi standard per la regolazione e 
la sintonia iniziale necessaria per il traffico quali ad es.: 

RY-RY; The Quick Brown Fox. 

Speciale attenzione inoltre è stata devoluta 
all’apprendimento della telegrafia: un generatore ad 
accesso casuale emette - a comando - i più disparati 
caratteri In CW, per cui l’operatore inesperto, 
regolando velocità e pesatura, potrà affidarsi a questo 
modo semplice, ma sempre sicuro 
di comunicare. 



Exclusive Agerrt 

Milano - Via F.lli Bronzetti. 37 (ang. C.so XXII Marzo) - Tel. 7386051 


TONO 













Come sarebbe oggi la legge di gravitazione universale 
se a Newton fosse caduto in testa un limone invece di una mela?* * 

LEMON H 

La risposta italiana ai personal computer americani. 


Microprocessore 6502 

Memoria RAM 48 K 

Memoria EP ROMS_12_K 

PERIFERICHE OPZIONALI 
- Unita disco mobile 5"- 8 ' 

• Stampanti seriali - parallele 

• Plotter - Tavola grafica 

• Risposta òlla domanda: UGUALE 


• Bus di espansione periferiche 

- I/O analogici/digitali 

- Uscita video compatibile_ 

Linguaggio residente BASIC ESTESO 

• Opzionale - Fortan • Pascal - Cobol • 
Possibilità grafica a colori e sintesi mu¬ 
sicale. 


Disponibilità di SOFTWARE indirizzato 
- Didattico - Scientifico 

• Applicativo - Gestionale 

• Hobbystico • Statistico 

Disponiamo inoltre di periferiche e prin¬ 
cipali micro e personal computer dis¬ 
tribuiti in Italia a prezzi promozionali. 


SELCOM elettronica RAVE nna dove anche tu 

divisione nuove tecnologie via Lametta. 9 - tei. 0544-35363 puoi 

































